diff options
author | Matthew Newhook <matthew@zeroc.com> | 2015-03-21 15:35:40 -0230 |
---|---|---|
committer | Matthew Newhook <matthew@zeroc.com> | 2015-03-21 15:35:40 -0230 |
commit | 630a37d2fe66f24518299e705f958b571803c522 (patch) | |
tree | 969723791bdc4d73bb099c19d45554d0ca241ad9 /python/test/Ice/timeout/Server.py | |
parent | Fix some README.md markdown formatting (diff) | |
download | ice-630a37d2fe66f24518299e705f958b571803c522.tar.bz2 ice-630a37d2fe66f24518299e705f958b571803c522.tar.xz ice-630a37d2fe66f24518299e705f958b571803c522.zip |
py -> python
rb -> ruby
objc -> objective-c
cs -> csharp
Diffstat (limited to 'python/test/Ice/timeout/Server.py')
-rwxr-xr-x | python/test/Ice/timeout/Server.py | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/python/test/Ice/timeout/Server.py b/python/test/Ice/timeout/Server.py new file mode 100755 index 00000000000..058491d9011 --- /dev/null +++ b/python/test/Ice/timeout/Server.py @@ -0,0 +1,81 @@ +#!/usr/bin/env python +# ********************************************************************** +# +# Copyright (c) 2003-2015 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. +# +# ********************************************************************** + +import os, sys, traceback, time, threading + +import Ice +slice_dir = Ice.getSliceDir() +if not slice_dir: + print(sys.argv[0] + ': Slice directory not found.') + sys.exit(1) + +Ice.loadSlice("'-I" + slice_dir + "' Test.ice") +import Test + +class ActivateAdapterThread(threading.Thread): + def __init__(self, adapter, timeout): + threading.Thread.__init__(self) + self._adapter = adapter + self._timeout = timeout + + def run(self): + time.sleep(self._timeout / 1000.0) + self._adapter.activate() + +class TimeoutI(Test.Timeout): + def op(self, current=None): + pass + + def sendData(self, data, current=None): + pass + + def sleep(self, timeout, current=None): + if timeout != 0: + time.sleep(timeout / 1000.0) + + def holdAdapter(self, to, current=None): + current.adapter.hold() + t = ActivateAdapterThread(current.adapter, to) + t.start() + + def shutdown(self, current=None): + current.adapter.getCommunicator().shutdown() + +def run(args, communicator): + communicator.getProperties().setProperty("TestAdapter.Endpoints", "default -p 12010:udp") + adapter = communicator.createObjectAdapter("TestAdapter") + adapter.add(TimeoutI(), communicator.stringToIdentity("timeout")) + adapter.activate() + communicator.waitForShutdown() + return True + +try: + initData = Ice.InitializationData() + initData.properties = Ice.createProperties(sys.argv) + initData.properties.setProperty("Ice.Warn.Connections", "0"); + # + # Limit the recv buffer size, this test relies on the socket + # send() blocking after sending a given amount of data. + # + initData.properties.setProperty("Ice.TCP.RcvSize", "50000"); + communicator = Ice.initialize(sys.argv, initData) + status = run(sys.argv, communicator) +except: + traceback.print_exc() + status = False + +if communicator: + try: + communicator.destroy() + except: + traceback.print_exc() + status = False + +sys.exit(not status) |