2 #include "ace/Get_Opt.h"
4 const ACE_TCHAR
*ior
= ACE_TEXT("file://test.ior");
7 parse_args (int argc
, ACE_TCHAR
*argv
[])
9 ACE_Get_Opt
get_opts (argc
, argv
, ACE_TEXT("k:"));
12 while ((c
= get_opts ()) != -1)
16 ior
= get_opts
.opt_arg ();
21 ACE_ERROR_RETURN ((LM_ERROR
,
28 // Indicates successful parsing of the command line
33 ACE_TMAIN(int argc
, ACE_TCHAR
*argv
[])
37 CORBA::ORB_var orb
= CORBA::ORB_init (argc
, argv
);
39 if (parse_args (argc
, argv
) != 0)
42 CORBA::Object_var tmp
= orb
->string_to_object(ior
);
44 Test::Hello_var hello
= Test::Hello::_narrow(tmp
.in ());
46 if (CORBA::is_nil (hello
.in ()))
48 ACE_ERROR_RETURN ((LM_DEBUG
,
49 "Nil Test::Hello reference <%s>\n",
56 CORBA::String_var the_string
= hello
->get_string ();
58 ACE_DEBUG ((LM_DEBUG
, "(%P|%t) - string returned <%C>\n",
61 // The *first* invocation of the get_string server always throws a COMPLETED_MAYBE exception. For the call to
62 // succeed we must have reinvoked breaking 'at most once' rules. The job is, therefore, a bogey.
63 ACE_ERROR ((LM_ERROR
, "Error - Regression - Test has failed. ORB has retried a COMPLETED_MAYBE\n"));
65 catch (const CORBA::TRANSIENT
& trans
)
67 // We are expecting a TRANSIENT COMPLETED_MAYBE.
68 if (trans
.completed () == CORBA::COMPLETED_MAYBE
)
70 // Everything is Peachy
79 catch (const CORBA::Exception
& ex
)
81 ex
._tao_print_exception ("Unexpected exception caught:");