summaryrefslogtreecommitdiff
path: root/cpp/test/Glacier2/sessionControl/run.py
blob: 982d6e725e069080abb716f15e9874339a0cee23 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#!/usr/bin/env python
# **********************************************************************
#
# 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.
#
# **********************************************************************

import os, sys, time

for toplevel in [".", "..", "../..", "../../..", "../../../.."]:
    toplevel = os.path.normpath(toplevel)
    if os.path.exists(os.path.join(toplevel, "config", "TestUtil.py")):
        break
else:
    raise "can't find toplevel directory!"

sys.path.append(os.path.join(toplevel, "config"))
import TestUtil

name = os.path.join("Glacier2", "sessionControl")
testdir = os.path.dirname(os.path.abspath(__file__))

server = os.path.join(testdir, "server")

print "starting server...",
serverPipe = TestUtil.startServer(server, " 2>&1")
TestUtil.getServerPid(serverPipe)
TestUtil.getAdapterReady(serverPipe)
print "ok"

router = os.path.join(TestUtil.getBinDir(__file__), "glacier2router")

args =    r' --Glacier2.Client.Endpoints="default -p 12347 -t 10000"' + \
          r' --Ice.Admin.Endpoints="tcp -h 127.0.0.1 -p 12348 -t 10000"' + \
          r' --Ice.Admin.InstanceName=Glacier2' + \
          r' --Glacier2.Server.Endpoints="default -p 12349 -t 10000"' + \
          r' --Glacier2.SessionManager="SessionManager:tcp -h 127.0.0.1 -p 12010 -t 10000"' \
          r' --Glacier2.PermissionsVerifier="Glacier2/NullPermissionsVerifier" 2>&1'

print "starting router...",
starterPipe = TestUtil.startServer(router, args)
TestUtil.getServerPid(starterPipe)
TestUtil.getAdapterReady(starterPipe)
print "ok"

client = os.path.join(testdir, "client")

#
# The test may sporadically fail without this slight pause.
#
time.sleep(1)

print "starting client...",
clientPipe = TestUtil.startClient(client, " 2>&1")
#TestUtil.getServerPid(clientPipe)
print "ok"

TestUtil.printOutputFromPipe(clientPipe)
clientStatus = TestUtil.closePipe(clientPipe)
if clientStatus:
    TestUtil.killServers()

if clientStatus or TestUtil.serverStatus():
    sys.exit(1)

sys.exit(0)