diff options
Diffstat (limited to 'trunk/TAO/tests/Collocation_Oneway_Tests/Client_Task.cpp')
-rw-r--r-- | trunk/TAO/tests/Collocation_Oneway_Tests/Client_Task.cpp | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/trunk/TAO/tests/Collocation_Oneway_Tests/Client_Task.cpp b/trunk/TAO/tests/Collocation_Oneway_Tests/Client_Task.cpp new file mode 100644 index 00000000000..216bcba8cf8 --- /dev/null +++ b/trunk/TAO/tests/Collocation_Oneway_Tests/Client_Task.cpp @@ -0,0 +1,115 @@ +// +// $Id$ +// + +#include "tao/Messaging/Messaging.h" +#include "tao/AnyTypeCode/Any.h" +#include "Client_Task.h" +#include "TestC.h" + +ACE_RCSID(Collocation_Oneway_Tests, Client_Task, "$Id$") + +Client_Task::Client_Task (const char *ior, + CORBA::ORB_ptr corb, + Client_Task::ClientSyncModeEnum syncMode, + ACE_Thread_Manager *thr_mgr) + : ACE_Task_Base (thr_mgr) + , input_ (ior) + , corb_ (CORBA::ORB::_duplicate (corb)) + , syncMode_ (syncMode) + +{ +} + +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); + } + + Test::Hello_var tmpVar = hello; + CORBA::Any anyPolicy; + + Messaging::SyncScope selectedScope = Messaging::SYNC_NONE; // default + + if(syncMode_ == Client_Task::MODE_TRANSPORT) { + selectedScope = Messaging::SYNC_WITH_TRANSPORT; + ACE_DEBUG ((LM_DEBUG, "(%P|%t) - SYNC_WITH_TRANSPORT collocated oneway test\n")); + } + else if(syncMode_ == Client_Task::MODE_SERVER) { + selectedScope = Messaging::SYNC_WITH_SERVER; + ACE_DEBUG ((LM_DEBUG, "(%P|%t) - SYNC_WITH_SERVER collocated oneway test\n")); + } + else if(syncMode_ == Client_Task::MODE_TARGET) { + selectedScope = Messaging::SYNC_WITH_TARGET; + ACE_DEBUG ((LM_DEBUG, "(%P|%t) - SYNC_WITH_TARGET collocated oneway test\n")); + } + else if(syncMode_ == Client_Task::MODE_NONE) { + selectedScope = Messaging::SYNC_NONE; + ACE_DEBUG ((LM_DEBUG, "(%P|%t) - SYNC_NONE collocated oneway test\n")); + } + + anyPolicy <<= selectedScope; + CORBA::PolicyList polList; + polList.length(1); + polList[0] = this->corb_->create_policy( + Messaging::SYNC_SCOPE_POLICY_TYPE, anyPolicy ACE_ENV_ARG_PARAMETER); + ACE_TRY_CHECK; + + CORBA::Object_var tmpGenericVar = + tmpVar->_set_policy_overrides(polList,CORBA::ADD_OVERRIDE ACE_ENV_ARG_PARAMETER); + ACE_TRY_CHECK; + + // do unchecked narrow because ORB's not activated. Otherwise get TRANSIENT exception + hello = Test::Hello::_narrow(tmpGenericVar.in()); + + 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 ())); + + hello->onewayTest(ACE_ENV_SINGLE_ARG_PARAMETER); + ACE_TRY_CHECK; + + ACE_DEBUG ((LM_DEBUG, "(%P|%t) - returned from onewayTest() call \n")); + + 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; + +} |