More tests update
[ACE_TAO.git] / TAO / tests / Bug_3636_Regression / server.cpp
blobcb9bc5bfc2bdc34d3dcf609adf6c0ea56ac08316
1 #include "Hello.h"
2 #include "ace/Get_Opt.h"
3 #include "ace/OS_NS_stdio.h"
4 #include "ace/Log_Msg.h"
6 const ACE_TCHAR *ior_output_file = ACE_TEXT ("test.ior");
8 int
9 parse_args (int argc, ACE_TCHAR *argv[])
11 ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("o:"));
12 int c;
14 while ((c = get_opts ()) != -1)
15 switch (c)
17 case 'o':
18 ior_output_file = get_opts.opt_arg ();
19 break;
21 case '?':
22 default:
23 ACE_ERROR_RETURN ((LM_ERROR,
24 "usage: %s "
25 "-o <iorfile>"
26 "\n",
27 argv [0]),
28 -1);
30 // Indicates successful parsing of the command line
31 return 0;
34 int
35 ACE_TMAIN(int argc, ACE_TCHAR *argv[])
37 int idle_count = 0;
38 try
40 CORBA::ORB_var orb =
41 CORBA::ORB_init (argc, argv);
43 CORBA::Object_var poa_object =
44 orb->resolve_initial_references("RootPOA");
46 PortableServer::POA_var root_poa =
47 PortableServer::POA::_narrow (poa_object.in ());
49 if (CORBA::is_nil (root_poa.in ()))
50 ACE_ERROR_RETURN ((LM_ERROR,
51 " (%P|%t) Panic: nil RootPOA\n"),
52 1);
54 PortableServer::POAManager_var poa_manager = root_poa->the_POAManager ();
56 if (parse_args (argc, argv) != 0)
57 return 1;
59 Hello *hello_impl = 0;
60 ACE_NEW_RETURN (hello_impl,
61 Hello (orb.in ()),
62 1);
63 PortableServer::ServantBase_var owner_transfer(hello_impl);
65 PortableServer::ObjectId_var id =
66 root_poa->activate_object (hello_impl);
68 CORBA::Object_var object = root_poa->id_to_reference (id.in ());
70 Test::Hello_var hello = Test::Hello::_narrow (object.in ());
72 CORBA::String_var ior = orb->object_to_string (hello.in ());
74 // Output the IOR to the <ior_output_file>
75 FILE *output_file= ACE_OS::fopen (ior_output_file, "w");
76 if (output_file == 0)
77 ACE_ERROR_RETURN ((LM_ERROR,
78 "Cannot open output file for writing IOR: %s\n",
79 ior_output_file),
80 1);
81 ACE_OS::fprintf (output_file, "%s", ior.in ());
82 ACE_OS::fclose (output_file);
84 poa_manager->activate ();
86 for (;;)
88 ACE_Time_Value tv (0, 500);
89 while (orb->work_pending (tv))
91 ACE_DEBUG ((LM_DEBUG, "Work pending\n"));
92 ACE_Time_Value tv2 (0, 500);
93 if (orb->work_pending (tv2))
95 ACE_Time_Value work_tv (0, 500);
96 orb->perform_work (work_tv);
99 ++idle_count;
102 orb->destroy ();
104 catch (const CORBA::BAD_INV_ORDER&)
106 // Expected
108 catch (const CORBA::Exception& ex)
110 ex._tao_print_exception ("Exception caught:");
111 return 1;
114 if (idle_count == 0)
116 ACE_ERROR_RETURN ((LM_ERROR, "ERROR: Got unexpected idle_count %d\n", idle_count), 1);
118 else
120 ACE_DEBUG ((LM_DEBUG, "Got %d idle moments\n", idle_count));
123 return 0;