diff options
Diffstat (limited to 'py/test/Ice/protobuf/Server.py')
-rwxr-xr-x | py/test/Ice/protobuf/Server.py | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/py/test/Ice/protobuf/Server.py b/py/test/Ice/protobuf/Server.py new file mode 100755 index 00000000000..9caa59fd1f7 --- /dev/null +++ b/py/test/Ice/protobuf/Server.py @@ -0,0 +1,68 @@ +#!/usr/bin/env python +# ********************************************************************** +# +# Copyright (c) 2003-2008 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 + +for toplevel in [".", "..", "../..", "../../..", "../../../.."]: + toplevel = os.path.normpath(toplevel) + if os.path.exists(os.path.join(toplevel, "python", "Ice.py")): + break +else: + raise "can't find toplevel directory!" + +import Ice + +# +# Get Slice directory. +# +slice_dir = os.path.join(os.path.join(toplevel, "..", "slice")) +if not os.path.exists(slice_dir): + print sys.argv[0] + ': Slice directory not found.' + sys.exit(1) + +Ice.loadSlice('-I' + slice_dir + ' Test.ice') +import Test +from Test_pb2 import Message + +class MyClassI(Test.MyClass): + def opMessage(self, m, current=None): + return (m, m) + + def opMessageAMD_async(self, cb, m, current=None): + cb.ice_response(m, m); + + def shutdown(self, current=None): + current.adapter.getCommunicator().shutdown() + +def run(args, communicator): + communicator.getProperties().setProperty("TestAdapter.Endpoints", "default -p 12010 -t 10000:udp") + adapter = communicator.createObjectAdapter("TestAdapter") + adapter.add(MyClassI(), communicator.stringToIdentity("test")) + adapter.activate() + communicator.waitForShutdown() + return True + +try: + initData = Ice.InitializationData() + initData.properties = Ice.createProperties(sys.argv) + 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) |