More tests update
[ACE_TAO.git] / TAO / tests / ClientPortSpan / client.cpp
blobc132a448177a2b63589d6158187f2f5a2e2056c0
1 #include "TestC.h"
2 #include "ace/Get_Opt.h"
3 #include "ace/OS_NS_unistd.h"
5 const ACE_TCHAR *ior = ACE_TEXT ("file://test.ior");
7 int
8 parse_args (int argc, ACE_TCHAR *argv[])
10 ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("k:"));
11 int c;
13 while ((c = get_opts ()) != -1)
14 switch (c)
16 case 'k':
17 ior = get_opts.opt_arg ();
18 break;
20 case '?':
21 default:
22 ACE_ERROR_RETURN ((LM_ERROR,
23 "usage: %s "
24 "-k <ior> "
25 "\n",
26 argv [0]),
27 -1);
29 // Indicates successful parsing of the command line
30 return 0;
33 int
34 ACE_TMAIN(int argc, ACE_TCHAR *argv[])
36 int result = 0;
37 try
39 CORBA::ORB_var orb = CORBA::ORB_init (argc, argv);
41 if (parse_args (argc, argv) != 0)
42 return 1;
44 CORBA::Object_var tmp = orb->string_to_object(ior);
46 Test::Hello_var hello = Test::Hello::_narrow(tmp.in ());
48 if (CORBA::is_nil (hello.in ()))
50 ACE_ERROR_RETURN ((LM_DEBUG,
51 "Nil Test::Hello reference <%s>\n",
52 ior),
53 1);
56 try
59 ACE_DEBUG ((LM_DEBUG, "(%P|%t) - calling get_string\n"));
60 CORBA::String_var the_string = hello->get_string ();
61 ACE_DEBUG ((LM_DEBUG, "(%P|%t) - string returned <%C>\n",
62 the_string.in ()));
63 ACE_OS::sleep (1);
64 hello->shutdown ();
66 catch (const CORBA::TRANSIENT& )
68 ACE_DEBUG ((LM_DEBUG, "(%P|%t) - caught expected transient\n"));
69 result = 1;
71 catch (const CORBA::COMM_FAILURE& )
73 ACE_DEBUG ((LM_DEBUG, "(%P|%t) - caught expected comm failure\n"));
76 orb->destroy ();
78 catch (const CORBA::Exception& ex)
80 ex._tao_print_exception ("Exception caught:");
81 result = 100;
84 return result;