// ********************************************************************** // // Copyright (c) 2003-2017 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 #include #include DEFINE_TEST("server") using namespace std; namespace { // // A no-op Logger, used when testing the Logger Admin // class NullLogger : public Ice::Logger #ifdef ICE_CPP11_MAPPING , public std::enable_shared_from_this #endif { public: virtual void print(const string&) { } virtual void trace(const string&, const string&) { } virtual void warning(const string&) { } virtual void error(const string&) { } virtual string getPrefix() { return "NullLogger"; } virtual Ice::LoggerPtr cloneWithPrefix(const string&) { return ICE_SHARED_FROM_THIS; } }; } int run(int, char**, const Ice::CommunicatorPtr& communicator) { communicator->getProperties()->setProperty("TestAdapter.Endpoints", getTestEndpoint(communicator, 0) + ":udp"); Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("TestAdapter"); Ice::Identity id = Ice::stringToIdentity("communicator"); adapter->add(ICE_MAKE_SHARED(RemoteCommunicatorI), id); adapter->activate(); TEST_READY // Disable ready print for further adapters. communicator->getProperties()->setProperty("Ice.PrintAdapterReady", "0"); communicator->waitForShutdown(); return EXIT_SUCCESS; } int main(int argc, char* argv[]) { #ifdef ICE_STATIC_LIBS Ice::registerIceSSL(); #endif try { Ice::InitializationData initData = getTestInitData(argc, argv); initData.properties->setProperty("Ice.Warn.Connections", "0"); initData.logger = ICE_MAKE_SHARED(NullLogger); Ice::CommunicatorHolder ich = Ice::initialize(argc, argv, initData); return run(argc, argv, ich.communicator()); } catch(const Ice::Exception& ex) { cerr << ex << endl; return EXIT_FAILURE; } }