summaryrefslogtreecommitdiff
path: root/TAO/tests/RTCORBA/Activate_Object_Multiple_ORBs/test.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/tests/RTCORBA/Activate_Object_Multiple_ORBs/test.cpp')
-rw-r--r--TAO/tests/RTCORBA/Activate_Object_Multiple_ORBs/test.cpp109
1 files changed, 109 insertions, 0 deletions
diff --git a/TAO/tests/RTCORBA/Activate_Object_Multiple_ORBs/test.cpp b/TAO/tests/RTCORBA/Activate_Object_Multiple_ORBs/test.cpp
new file mode 100644
index 00000000000..8dd1103b673
--- /dev/null
+++ b/TAO/tests/RTCORBA/Activate_Object_Multiple_ORBs/test.cpp
@@ -0,0 +1,109 @@
+// $Id$
+
+// *******************************************************************
+//
+// This test links in RTCORBA and RTPortableServer and creates two
+// distinct RT ORB's. It then activates an object using the RT POA
+// from each RT ORB. Prior to fixing the TAO_Policy_Validator,
+// activating the second object would cause a segmentation fault.
+// This was caused by the RT Policy Validator not being added correctly
+// to the ORB Core's policy validator list.
+//
+// *******************************************************************
+
+#include "tao/corba.h"
+#include "testS.h"
+
+class TestMonitorable_i: public virtual POA_Arch_Idl::Monitorable
+{
+public:
+ TestMonitorable_i () {}
+};
+
+
+int main(int, char**)
+{
+ ACE_DECLARE_NEW_CORBA_ENV;
+ ACE_TRY
+ {
+ int argc = 0;
+ CORBA::ORB_var orb1 =
+ CORBA::ORB_init(argc, 0, "orb1" ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ CORBA::ORB_var orb2 =
+ CORBA::ORB_init(argc, 0, "orb2" ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ CORBA::Object_var poaObj_var =
+ orb1->resolve_initial_references ("RootPOA"
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ PortableServer::POA_var rootPoa =
+ PortableServer::POA::_narrow (poaObj_var.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ PortableServer::POAManager_var poaManager =
+ rootPoa->the_POAManager (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ CORBA::Object_var poaObj_var2 =
+ orb2->resolve_initial_references ("RootPOA"
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ PortableServer::POA_var rootPoa2 =
+ PortableServer::POA::_narrow (poaObj_var2.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ PortableServer::POAManager_var poaManager2 =
+ rootPoa2->the_POAManager (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ poaManager2->activate (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ poaManager->activate (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ TestMonitorable_i* monitorable_i = 0;
+ ACE_NEW_RETURN (monitorable_i, TestMonitorable_i, 1);
+ PortableServer::ServantBase_var monitorable_var = monitorable_i;
+
+ TestMonitorable_i* m2 = 0;
+ ACE_NEW_RETURN (m2, TestMonitorable_i, 1);
+ PortableServer::ServantBase_var m2_var = m2;
+
+ PortableServer::ObjectId_var monitorableId1_var =
+ rootPoa->activate_object (monitorable_var.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ CORBA::Object_var obj1 =
+ rootPoa->id_to_reference (monitorableId1_var.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ Arch_Idl::Monitorable_var monitorable1 =
+ Arch_Idl::Monitorable::_narrow (obj1.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ PortableServer::ObjectId_var monitorableId2_var =
+ rootPoa2->activate_object (m2_var.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ CORBA::Object_var obj2 =
+ rootPoa2->id_to_reference (monitorableId2_var.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ Arch_Idl::Monitorable_var monitorable2 =
+ Arch_Idl::Monitorable::_narrow (obj2.in ()
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Caught exception:");
+ return 1;
+ }
+ ACE_ENDTRY;
+
+ return 0;
+}