summaryrefslogtreecommitdiff
path: root/trunk/TAO/orbsvcs/tests/CosEvent/Basic/Shutdown.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/TAO/orbsvcs/tests/CosEvent/Basic/Shutdown.cpp')
-rw-r--r--trunk/TAO/orbsvcs/tests/CosEvent/Basic/Shutdown.cpp181
1 files changed, 181 insertions, 0 deletions
diff --git a/trunk/TAO/orbsvcs/tests/CosEvent/Basic/Shutdown.cpp b/trunk/TAO/orbsvcs/tests/CosEvent/Basic/Shutdown.cpp
new file mode 100644
index 00000000000..85ec4180e9f
--- /dev/null
+++ b/trunk/TAO/orbsvcs/tests/CosEvent/Basic/Shutdown.cpp
@@ -0,0 +1,181 @@
+// $Id$
+
+#include "Counting_Consumer.h"
+#include "Counting_Supplier.h"
+#include "orbsvcs/CosEvent/CEC_EventChannel.h"
+#include "orbsvcs/CosEvent/CEC_Default_Factory.h"
+
+ACE_RCSID( CEC_Tests_Basic,
+ Shutdown,
+ "$Id$")
+
+static void run_test (PortableServer::POA_ptr poa,
+ int with_callbacks
+ ACE_ENV_ARG_DECL);
+
+int
+main (int argc, char* argv[])
+{
+ TAO_CEC_Default_Factory::init_svcs ();
+
+ ACE_DECLARE_NEW_CORBA_ENV;
+ ACE_TRY
+ {
+ // ORB initialization boiler plate...
+ CORBA::ORB_var orb =
+ CORBA::ORB_init (argc, argv, "" ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ CORBA::Object_var object =
+ orb->resolve_initial_references ("RootPOA" ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ PortableServer::POA_var poa =
+ PortableServer::POA::_narrow (object.in () ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ PortableServer::POAManager_var poa_manager =
+ poa->the_POAManager (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ poa_manager->activate (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ // ****************************************************************
+
+ run_test (poa.in (), 0 ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ run_test (poa.in (), 1 ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ // ****************************************************************
+
+ poa->destroy (1, 1 ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ orb->destroy (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION, "Service");
+ return 1;
+ }
+ ACE_ENDTRY;
+ return 0;
+}
+
+void
+deactivate_servant (PortableServer::Servant servant
+ ACE_ENV_ARG_DECL)
+{
+ PortableServer::POA_var poa =
+ servant->_default_POA (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+ PortableServer::ObjectId_var id =
+ poa->servant_to_id (servant ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ poa->deactivate_object (id.in () ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+}
+
+static void
+run_test (PortableServer::POA_ptr poa,
+ int with_callbacks
+ ACE_ENV_ARG_DECL)
+{
+ TAO_CEC_EventChannel_Attributes attributes (poa,
+ poa);
+ attributes.disconnect_callbacks = with_callbacks;
+
+ TAO_CEC_EventChannel ec_impl (attributes);
+ ec_impl.activate (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+
+ CosEventChannelAdmin::EventChannel_var event_channel =
+ ec_impl._this (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+
+ // ****************************************************************
+
+ // Obtain the consumer admin..
+ CosEventChannelAdmin::ConsumerAdmin_var consumer_admin =
+ event_channel->for_consumers (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+
+ // Obtain the supplier admin..
+ CosEventChannelAdmin::SupplierAdmin_var supplier_admin =
+ event_channel->for_suppliers (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+
+ // ****************************************************************
+
+ CEC_Counting_Consumer **consumer = 0;
+ CEC_Counting_Supplier **supplier = 0;
+
+ const int n = 200;
+ ACE_NEW (consumer, CEC_Counting_Consumer*[n]);
+ ACE_NEW (supplier, CEC_Counting_Supplier*[n]);
+
+ int i = 0;
+ for (i = 0; i != n; ++i)
+ {
+ char consumer_name[64];
+ ACE_OS::sprintf (consumer_name, "Consumer/%4.4d", i);
+ ACE_NEW (consumer[i],
+ CEC_Counting_Consumer (consumer_name));
+
+ ACE_NEW (supplier[i], CEC_Counting_Supplier ());
+ }
+
+ for (i = 0; i != n; ++i)
+ {
+ consumer[i]->connect (consumer_admin.in () ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+
+ supplier[i]->connect (supplier_admin.in () ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ }
+
+ // ****************************************************************
+
+ // Destroy the event channel, *before* disconnecting the
+ // clients.
+ event_channel->destroy (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+
+ // ****************************************************************
+
+ for (i = 0; i != n; ++i)
+ {
+ if (consumer[i]->disconnect_count != 1)
+ ACE_DEBUG ((LM_DEBUG,
+ "ERRROR unexpected "
+ "disconnect count (%d) in Consumer/%04.4d\n",
+ consumer[i]->disconnect_count,
+ i));
+
+ if (supplier[i]->disconnect_count != 1)
+ ACE_DEBUG ((LM_DEBUG,
+ "ERRROR unexpected "
+ "disconnect count (%d) in Supplier/%04.4d\n",
+ supplier[i]->disconnect_count,
+ i));
+ }
+
+ // ****************************************************************
+
+ for (i = 0; i != n; ++i)
+ {
+ deactivate_servant (supplier[i] ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ delete supplier[i];
+
+ deactivate_servant (consumer[i] ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ delete consumer[i];
+ }
+ delete[] supplier;
+ delete[] consumer;
+
+ deactivate_servant (&ec_impl ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+}