summaryrefslogtreecommitdiff
path: root/trunk/TAO/tests/Collocation_Exception_Test/Client_Task.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/TAO/tests/Collocation_Exception_Test/Client_Task.cpp')
-rw-r--r--trunk/TAO/tests/Collocation_Exception_Test/Client_Task.cpp141
1 files changed, 141 insertions, 0 deletions
diff --git a/trunk/TAO/tests/Collocation_Exception_Test/Client_Task.cpp b/trunk/TAO/tests/Collocation_Exception_Test/Client_Task.cpp
new file mode 100644
index 00000000000..960fef211e1
--- /dev/null
+++ b/trunk/TAO/tests/Collocation_Exception_Test/Client_Task.cpp
@@ -0,0 +1,141 @@
+//
+// $Id$
+//
+
+#include "Client_Task.h"
+
+ACE_RCSID(Collocation_Oneway_Tests, Client_Task, "$Id$")
+
+Client_Task::Client_Task (const char *ior,
+ CORBA::ORB_ptr corb,
+ ACE_Thread_Manager *thr_mgr)
+ : ACE_Task_Base (thr_mgr)
+ , input_ (ior)
+ , corb_ (CORBA::ORB::_duplicate (corb))
+{
+}
+
+void
+Client_Task::test_system_exception (
+ Test::Hello_ptr hello_ptr ACE_ENV_ARG_DECL)
+{
+ ACE_TRY
+ {
+ hello_ptr->system_exception_test (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ ACE_CATCH (CORBA::INTERNAL, ex)
+ {
+ ACE_DEBUG ((LM_DEBUG, "(%P|%t) - Caught internal exception as expected\n"));
+ // ignore
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Unexpected exception caught in test_system_exception:");
+ ACE_RE_THROW;
+ }
+ ACE_ENDTRY;
+ ACE_CHECK;
+}
+
+void
+Client_Task::test_user_exception_expected (
+ Test::Hello_ptr hello_ptr ACE_ENV_ARG_DECL)
+{
+ ACE_TRY
+ {
+ hello_ptr->user_exception_expected (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ ACE_CATCH (::Test::Hello::A, ex)
+ {
+ ACE_DEBUG ((LM_DEBUG, "(%P|%t) - Caught user A exception as expected\n"));
+ // ignore
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Unexpected exception caught in test_user_exception_expected:");
+ ACE_RE_THROW;
+ }
+ ACE_ENDTRY;
+ ACE_CHECK;
+}
+
+void
+Client_Task::test_user_exception_not_expected (
+ Test::Hello_ptr hello_ptr ACE_ENV_ARG_DECL)
+{
+ ACE_TRY
+ {
+ hello_ptr->user_exception_not_expected (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ ACE_CATCH (CORBA::UNKNOWN, ex)
+ {
+ ACE_DEBUG ((LM_DEBUG, "(%P|%t) - Caught unknown exception as expected\n"));
+ // ignore
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Unexpected exception caught in user_exception_not_expected:");
+ ACE_RE_THROW;
+ }
+ ACE_ENDTRY;
+ ACE_CHECK;
+}
+
+int
+Client_Task::svc (void)
+{
+ ACE_TRY_NEW_ENV
+ {
+ CORBA::Object_var tmp =
+ this->corb_->string_to_object (input_
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ Test::Hello_var hello =
+ Test::Hello::_narrow(tmp.in () ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ if (CORBA::is_nil (hello.in ()))
+ {
+ ACE_ERROR_RETURN ((LM_DEBUG,
+ "Nil Test::Hello reference <%s>\n",
+ input_),
+ 1);
+ }
+
+ CORBA::String_var the_string =
+ hello->get_string (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ ACE_DEBUG ((LM_DEBUG, "(%P|%t) - string returned <%s>\n",
+ the_string.in ()));
+
+ this->test_system_exception (hello.in () ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ this->test_user_exception_expected (hello.in () ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ this->test_user_exception_not_expected (hello.in () ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ hello->shutdown (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Exception caught:");
+ return 1;
+ }
+ ACE_ENDTRY;
+
+ return 0;
+
+}