diff options
author | Joe George <joe@zeroc.com> | 2015-03-03 17:30:50 -0500 |
---|---|---|
committer | Joe George <joe@zeroc.com> | 2015-05-12 11:41:55 -0400 |
commit | d35bb9f5c19e34aee31f83d445695a8186ef675e (patch) | |
tree | d5324eaf44f5f9776495537c51653f50a66a7237 /cpp/test/Ice/threadPoolPriority/ServerCustomThreadPool.cpp | |
download | ice-d35bb9f5c19e34aee31f83d445695a8186ef675e.tar.bz2 ice-d35bb9f5c19e34aee31f83d445695a8186ef675e.tar.xz ice-d35bb9f5c19e34aee31f83d445695a8186ef675e.zip |
Ice 3.4.2 Source Distributionv3.4.2
Diffstat (limited to 'cpp/test/Ice/threadPoolPriority/ServerCustomThreadPool.cpp')
-rw-r--r-- | cpp/test/Ice/threadPoolPriority/ServerCustomThreadPool.cpp | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/cpp/test/Ice/threadPoolPriority/ServerCustomThreadPool.cpp b/cpp/test/Ice/threadPoolPriority/ServerCustomThreadPool.cpp new file mode 100644 index 00000000000..ef106d24b5d --- /dev/null +++ b/cpp/test/Ice/threadPoolPriority/ServerCustomThreadPool.cpp @@ -0,0 +1,92 @@ +// ********************************************************************** +// +// Copyright (c) 2003-2011 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 <Ice/Ice.h> +#include <TestI.h> +#include <TestCommon.h> + +using namespace std; + +int +run(int argc, char* argv[], const Ice::CommunicatorPtr& communicator) +{ + Ice::PropertiesPtr properties = communicator->getProperties(); + properties->setProperty("Ice.Warn.Dispatch", "0"); + communicator->getProperties()->setProperty("TestAdapter.Endpoints", "default -p 12010 -t 10000:udp"); + communicator->getProperties()->setProperty("TestAdapter.ThreadPool.Size", "1"); + + // + // First try to use an invalid priority. + // + communicator->getProperties()->setProperty("TestAdapter.ThreadPool.ThreadPriority", "1024"); + try + { + Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("TestAdapter"); + test(false); + } + catch(const IceUtil::ThreadSyscallException&) + { + //expected + } + catch(...) + { + test(false); + } + + // + // Now set the priority correctly. + // + +#ifdef _WIN32 + communicator->getProperties()->setProperty("Ice.ThreadPool.Server.ThreadPriority", "-1"); + communicator->getProperties()->setProperty("TestAdapter.ThreadPool.ThreadPriority", "1"); +#else + communicator->getProperties()->setProperty("Ice.ThreadPool.Server.ThreadPriority", "10"); + communicator->getProperties()->setProperty("TestAdapter.ThreadPool.ThreadPriority", "50"); +#endif + Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("TestAdapter"); + Ice::ObjectPtr object = new PriorityI(adapter); + adapter->add(object, communicator->stringToIdentity("test")); + adapter->activate(); + communicator->waitForShutdown(); + return EXIT_SUCCESS; +} + +int +main(int argc, char* argv[]) +{ + int status; + Ice::CommunicatorPtr communicator; + + try + { + communicator = Ice::initialize(argc, argv); + 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; +} |