#include "TestC.h" #include "ace/Get_Opt.h" #include "ace/Task_T.h" #include "ace/OS_NS_unistd.h" #include "tao/TimeBaseC.h" #include "tao/Messaging/Messaging.h" const ACE_TCHAR *ior = ACE_TEXT ("file://test.ior"); bool shutdown_server = false; int parse_args (int argc, ACE_TCHAR *argv[]) { ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("k:x")); int c; while ((c = get_opts ()) != -1) switch (c) { case 'k': ior = get_opts.opt_arg (); break; case 'x': shutdown_server = true; break; case '?': default: ACE_ERROR_RETURN ((LM_ERROR, "usage: %s " "-k " "\n", argv [0]), -1); } // Indicates successful parsing of the command line return 0; } class Client : public ACE_Task_Base { public: Client (CORBA::ORB_ptr server); virtual int svc (); private: CORBA::ORB_var orb_; }; int ACE_TMAIN(int argc, ACE_TCHAR *argv[]) { try { CORBA::ORB_var orb = CORBA::ORB_init (argc, argv); if (parse_args (argc, argv) != 0) return 1; // Set round-trip timeout const int timeout_secs = 5; CORBA::Object_var obj = orb->resolve_initial_references ("ORBPolicyManager"); CORBA::PolicyManager_var policy_manager = CORBA::PolicyManager::_narrow (obj.in()); CORBA::PolicyList policy_list; policy_list.length(0); policy_manager->set_policy_overrides(policy_list, CORBA::SET_OVERRIDE); TimeBase::TimeT timeout = timeout_secs * 10000000; CORBA::Any orb_timeout; orb_timeout <<= timeout; policy_list.length(1); policy_list[0] = orb->create_policy( Messaging::RELATIVE_RT_TIMEOUT_POLICY_TYPE, orb_timeout); policy_manager->set_policy_overrides(policy_list, CORBA::SET_OVERRIDE); CORBA::Object_var tmp = orb->string_to_object(ior); Test::Hello_var hello = Test::Hello::_narrow(tmp.in ()); if (CORBA::is_nil (hello.in ())) { ACE_ERROR_RETURN ((LM_DEBUG, "Nil Test::Hello reference <%s>\n", ior), 1); } if (shutdown_server) { ACE_DEBUG ((LM_DEBUG, "(%P|%t) Calling shutdown on server\n")); hello->shutdown (); } else { Client client (orb.in ()); if (client.activate (THR_NEW_LWP | THR_JOINABLE, 1) != 0) ACE_ERROR_RETURN ((LM_ERROR, "Cannot activate client threads\n"), 1); CORBA::String_var the_string; try { the_string = hello->get_string (); } catch (const CORBA::TIMEOUT&) { ACE_DEBUG ((LM_DEBUG, "(%P|%t) Error: got timeout\n")); } catch (const CORBA::COMM_FAILURE&) { ACE_DEBUG ((LM_DEBUG, "(%P|%t) Ok: got comm exception\n")); } ACE_DEBUG ((LM_DEBUG, "(%P|%t) - string returned <%C>\n", the_string.in ())); client.thr_mgr ()->wait (); } orb->destroy (); } catch (const CORBA::Exception& ex) { ex._tao_print_exception ("Exception caught:"); return 1; } return 0; } Client::Client (CORBA::ORB_ptr orb) : orb_ (CORBA::ORB::_duplicate (orb)) { } int Client::svc (void) { try { ACE_OS::sleep (2); ACE_DEBUG ((LM_DEBUG, "(%P|%t) Shutting down ORB\n")); orb_->shutdown (true); } catch (const CORBA::Exception&) { } return 0; }