summaryrefslogtreecommitdiff
path: root/cpp/test/Ice/background/Server.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/test/Ice/background/Server.cpp')
-rw-r--r--cpp/test/Ice/background/Server.cpp171
1 files changed, 171 insertions, 0 deletions
diff --git a/cpp/test/Ice/background/Server.cpp b/cpp/test/Ice/background/Server.cpp
new file mode 100644
index 00000000000..45358ed96c7
--- /dev/null
+++ b/cpp/test/Ice/background/Server.cpp
@@ -0,0 +1,171 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2007 ZeroC, Inc. All rights reserved.
+//
+// This copy of Ice is licensed to you under the terms described in the
+// ICE_LICENSE file included in this distribution.
+//
+// **********************************************************************
+
+#include <IceUtil/DisableWarnings.h>
+#include <Ice/Ice.h>
+#include <TestI.h>
+#include <Configuration.h>
+#include <PluginI.h>
+
+#include <Ice/Locator.h>
+#include <Ice/Router.h>
+
+using namespace std;
+
+class LocatorI : public Ice::Locator
+{
+public:
+
+ virtual void
+ findAdapterById_async(const Ice::AMD_Locator_findAdapterByIdPtr& response, const string& adapter,
+ const Ice::Current& current) const
+ {
+ _controller->checkCallPause(current);
+ Ice::CommunicatorPtr communicator = current.adapter->getCommunicator();
+ response->ice_response(current.adapter->createDirectProxy(communicator->stringToIdentity("dummy")));
+ }
+
+ virtual void
+ findObjectById_async(const Ice::AMD_Locator_findObjectByIdPtr& response, const Ice::Identity& id,
+ const Ice::Current& current) const
+ {
+ _controller->checkCallPause(current);
+ Ice::CommunicatorPtr communicator = current.adapter->getCommunicator();
+ response->ice_response(current.adapter->createDirectProxy(id));
+ }
+
+ virtual Ice::LocatorRegistryPrx
+ getRegistry(const Ice::Current&) const
+ {
+ return 0;
+ }
+
+ LocatorI(const BackgroundControllerIPtr& controller) : _controller(controller)
+ {
+ }
+
+private:
+
+ BackgroundControllerIPtr _controller;
+};
+
+class RouterI : public Ice::Router
+{
+public:
+
+ virtual Ice::ObjectPrx
+ getClientProxy(const Ice::Current& current) const
+ {
+ _controller->checkCallPause(current);
+ return 0;
+ }
+
+ virtual Ice::ObjectPrx
+ getServerProxy(const Ice::Current& current) const
+ {
+ _controller->checkCallPause(current);
+ return 0;
+ }
+
+ virtual void
+ addProxy(const Ice::ObjectPrx&, const Ice::Current&)
+ {
+ }
+
+ virtual Ice::ObjectProxySeq
+ addProxies(const Ice::ObjectProxySeq&, const Ice::Current&)
+ {
+ return Ice::ObjectProxySeq();
+ }
+
+ RouterI(const BackgroundControllerIPtr& controller)
+ {
+ _controller = controller;
+ }
+
+private:
+
+ BackgroundControllerIPtr _controller;
+};
+
+
+int
+run(int argc, char* argv[], const Ice::CommunicatorPtr& communicator)
+{
+ communicator->getProperties()->setProperty("TestAdapter.Endpoints", "default -p 12010 -t 10000");
+ communicator->getProperties()->setProperty("ControllerAdapter.Endpoints", "tcp -p 12011");
+ communicator->getProperties()->setProperty("ControllerAdapter.ThreadPool.Size", "1");
+
+ Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("TestAdapter");
+ Ice::ObjectAdapterPtr adapter2 = communicator->createObjectAdapter("ControllerAdapter");
+
+ PluginI* plugin = dynamic_cast<PluginI*>(communicator->getPluginManager()->getPlugin("Test").get());
+ assert(plugin);
+ ConfigurationPtr configuration = plugin->getConfiguration();
+ BackgroundControllerIPtr backgroundController = new BackgroundControllerI(adapter, configuration);
+
+ adapter->add(new BackgroundI(backgroundController), communicator->stringToIdentity("background"));
+ adapter->add(new LocatorI(backgroundController), communicator->stringToIdentity("locator"));
+ adapter->add(new RouterI(backgroundController), communicator->stringToIdentity("router"));
+ adapter->activate();
+
+ adapter2->add(backgroundController, communicator->stringToIdentity("backgroundController"));
+ adapter2->activate();
+
+ communicator->waitForShutdown();
+ return EXIT_SUCCESS;
+}
+
+int
+main(int argc, char* argv[])
+{
+ int status;
+ Ice::CommunicatorPtr communicator;
+
+ try
+ {
+ Ice::InitializationData initData;
+ initData.properties = Ice::createProperties(argc, argv);
+
+ //
+ // This test kills connections, so we don't want warnings.
+ //
+ initData.properties->setProperty("Ice.Warn.Connections", "0");
+
+ //
+ // Setup the test transport plugin.
+ //
+ initData.properties->setProperty("Ice.Plugin.Test", "TestTransport:createTestTransport");
+ string defaultProtocol = initData.properties->getPropertyWithDefault("Ice.Default.Protocol", "tcp");
+ initData.properties->setProperty("Ice.Default.Protocol", "test-" + defaultProtocol);
+
+ communicator = Ice::initialize(argc, argv, initData);
+ status = run(argc, argv, communicator);
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+
+ if(communicator)
+ {
+ try
+ {
+ communicator->destroy();
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+ }
+
+ return status;
+}