summaryrefslogtreecommitdiff
path: root/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/TAO/tests/Stack_Recursion/Client_Task.cpp')
-rw-r--r--trunk/TAO/tests/Stack_Recursion/Client_Task.cpp72
1 files changed, 72 insertions, 0 deletions
diff --git a/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp b/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp
new file mode 100644
index 00000000000..58747bad1e4
--- /dev/null
+++ b/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp
@@ -0,0 +1,72 @@
+//
+// $Id$
+//
+
+#include "Client_Task.h"
+
+ACE_RCSID(Stack_Recursion,
+ Client_Task,
+ "$Id$")
+
+Client_Task::Client_Task (Test::Sender_ptr sender,
+ CORBA::Long event_count,
+ CORBA::ULong event_size,
+ ACE_Thread_Manager *thr_mgr)
+ : ACE_Task_Base (thr_mgr)
+ , sender_ (Test::Sender::_duplicate (sender))
+ , event_count_ (event_count)
+ , event_size_ (event_size)
+{
+}
+
+int
+Client_Task::svc (void)
+{
+ ACE_DEBUG ((LM_DEBUG, "(%P|%t) Starting client task\n"));
+
+ ACE_DECLARE_NEW_CORBA_ENV;
+ ACE_TRY
+ {
+ this->validate_connections (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ for (int i = 0; i != this->event_count_; ++i)
+ {
+#if 0
+ if (i%100 == 0)
+ ACE_DEBUG ((LM_DEBUG,
+ "(%P|%t) In iteration [%d] ....\n",
+ i));
+#endif /*if 0*/
+ Test::Payload_var pl = new Test::Payload;
+ Test::Payload_out payload (pl.out ());
+ this->sender_->get_data (this->event_size_,
+ payload
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ }
+ ACE_CATCHANY
+ {
+ return -1;
+ }
+ ACE_ENDTRY;
+ ACE_DEBUG ((LM_DEBUG, "(%P|%t) Client task finished\n"));
+ return 0;
+}
+
+
+void
+Client_Task::validate_connections (ACE_ENV_SINGLE_ARG_DECL)
+{
+ for (int i = 0 ; i != 100; i++)
+ {
+ ACE_TRY
+ {
+ this->sender_->ping (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ }
+ ACE_CATCHANY {} ACE_ENDTRY;
+ }
+}