Merge pull request #1844 from jrw972/monterey
[ACE_TAO.git] / TAO / tests / DII_Deferred_Transient / client.cpp
blob98baad26c9f2f63c5699d66f9bbcc80b0011a1d9
1 // -*- C++ -*-
2 #include "tao/DynamicInterface/Request.h"
3 #include "tao/DynamicInterface/DII_CORBA_methods.h"
4 #include "TestC.h"
5 #include "ace/Get_Opt.h"
6 #include "ace/OS_NS_unistd.h"
8 const ACE_TCHAR *ior = ACE_TEXT("file://test.ior");
10 int
11 parse_args (int argc, ACE_TCHAR *argv[])
13 ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("k:"));
14 int c;
16 while ((c = get_opts ()) != -1)
17 switch (c)
19 case 'k':
20 ior = get_opts.opt_arg ();
21 break;
23 case '?':
24 default:
25 ACE_ERROR_RETURN ((LM_ERROR,
26 "usage: %s "
27 "-k <ior> "
28 "\n",
29 argv [0]),
30 -1);
32 // Indicates successful parsing of the command line
33 return 0;
36 int
37 ACE_TMAIN(int argc, ACE_TCHAR *argv[])
39 try
41 CORBA::ORB_var orb = CORBA::ORB_init (argc, argv);
43 if (parse_args (argc, argv) != 0)
44 return 1;
46 CORBA::Object_var obj = orb->string_to_object(ior);
48 const char* the_string = 0;
50 ACE_DEBUG ((LM_INFO, "(%P|%t) - #### Deferred twoway DII (using get_response())\n"));
52 CORBA::Request_var req = obj->_request ("get_string");
53 req->set_return_type (CORBA::_tc_string);
55 req->send_deferred ();
56 ACE_DEBUG ((LM_INFO, "(%P|%t) - Get response...\n"));
57 req->get_response ();
58 req->return_value () >>= the_string;
60 ACE_DEBUG ((LM_DEBUG, "(%P|%t) - string returned <%C>\n",
61 the_string));
63 ACE_DEBUG ((LM_INFO, "(%P|%t) - #### Oneway DII to initiate crash\n"));
65 req = obj->_request ("crash");
67 req->send_oneway ();
69 ACE_OS::sleep(1); // give it some time
71 ACE_DEBUG ((LM_INFO, "(%P|%t) - #### Multiple deferred twoway DII (with discarded replies)\n"));
73 int iterations = 10;
74 int exceptions = 0;
75 for (int i=0; i<iterations ;++i)
77 try
79 ACE_DEBUG ((LM_INFO, "(%P|%t) - get_string iteration #%d\n", i));
81 req = obj->_request ("get_string");
82 req->set_return_type (CORBA::_tc_string);
84 req->send_deferred ();
85 // discard reply
87 ACE_DEBUG ((LM_INFO, "(%P|%t) - sent deferred\n"));
89 catch (const CORBA::Exception&)
91 ++exceptions;
95 if (exceptions == 0)
97 ACE_DEBUG ((LM_ERROR, "(%P|%t) - All requests unexpectedly succeeded\n"));
99 else
101 ACE_DEBUG ((LM_INFO, "(%P|%t) - Caught exceptions from requests as expected (%d)\n", exceptions));
104 orb->destroy ();
106 catch (const CORBA::Exception& ex)
108 ex._tao_print_exception ("Exception caught:");
109 return 1;
112 return 0;