Client::Client (A::AMI_Test_ptr server, int niterations) : ami_test_var_ (A::AMI_Test::_duplicate (server)), niterations_ (niterations) { the_handler_var_ = handler._this (/* */); }
int ACE_TMAIN(int argc, ACE_TCHAR *argv[]) { ACE_START_TEST (ACE_TEXT ("HTIOP_AMI_simple_client")); try { CORBA::ORB_var orb = CORBA::ORB_init (argc, argv); CORBA::Object_var object_var = orb->resolve_initial_references ("RootPOA"); PortableServer::POA_var poa_var = PortableServer::POA::_narrow (object_var.in ()); PortableServer::POAManager_var poa_manager_var = poa_var->the_POAManager (); poa_manager_var->activate (); if (parse_args (argc, argv) != 0) return 1; // We reuse the object_var smart pointer! object_var = orb->string_to_object (ior); A::AMI_Test_var ami_test_var = A::AMI_Test::_narrow (object_var.in ()); if (CORBA::is_nil (ami_test_var.in ())) { ACE_ERROR_RETURN ((LM_ERROR, "Object reference <%s> is nil\n", ior), 1); } ACE_OS::socket_init (); // Instantiate the ReplyHandler and register that with the POA. Handler handler; A::AMI_AMI_TestHandler_var the_handler_var = handler._this (); // Try out sending asynchronous messages without a reply handler // registered. Things fail if we get an exception. ami_test_var->sendc_foo (A::AMI_AMI_TestHandler::_nil (), 0, ""); // Trigger the DidTheRightThing exception on the server side // by sending 0 to it. ACE_DEBUG ((LM_DEBUG, "Sending asynch message\n")); ami_test_var->sendc_foo (the_handler_var.in (), 0, "Let's talk AMI."); CORBA::Long l = 931247; for (ssize_t ni = 0; ni < niterations; ni++) { ACE_DEBUG ((LM_DEBUG, "Sending asynch message: %d\n", ni)); ami_test_var->sendc_foo (the_handler_var.in (), l, "Let's talk AMI."); } // Begin test of attributes ami_test_var->sendc_get_yadda (the_handler_var.in ()); ami_test_var->sendc_set_yadda (the_handler_var.in (), 4711); ami_test_var->sendc_get_yadda (the_handler_var.in ()); // End test of attributes if (debug) { ACE_DEBUG ((LM_DEBUG, "<%d> Asynchronous methods issued\n", niterations)); } if (debug) { ACE_DEBUG ((LM_DEBUG, "Issuing a synchronous method to collect the AMI replies\n")); } //while (orb->work_pending()) // orb->perform_work (); CORBA::Long number = ami_test_var->foo (l, l, "Let's talk SMI."); if (debug) { ACE_DEBUG ((LM_DEBUG, "Received the following number: %d\n", number)); } if (shutdown_flag) { ACE_DEBUG ((LM_DEBUG, "invoking shutdown\n")); ami_test_var->shutdown (); } poa_var->destroy (1, // ethernalize objects 0 // wait for completion ); orb->destroy (); } catch (const CORBA::Exception& ex) { ex._tao_print_exception ("Caught exception:"); return 1; } ACE_END_TEST; return 0; }