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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
#!/usr/bin/env python
# **********************************************************************
#
# Copyright (c) 2003-2006 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, getopt
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
def usage():
print "usage: " + sys.argv[0] + " [-m]"
sys.exit(2)
try:
opts, args = getopt.getopt(sys.argv[1:], "m")
except getopt.GetoptError:
usage()
mono = 0
for o, a in opts:
if o == "-m":
mono = 1
if not TestUtil.isWin32():
mono = 1
name = os.path.join("Ice", "faultTolerance")
testdir = os.path.join(toplevel, "test", name)
server = os.path.join(testdir, "server")
client = os.path.join(testdir, "client")
if TestUtil.isCygwin():
print "\nYou may get spurious \"Signal 127\" messages during this test run."
print "These are expected and can be safely ignored.\n"
num = 12
base = 12340
serverPipes = { }
for i in range(0, num):
msg = "starting "
if mono:
msg += "mono "
msg += "server"
if mono:
msg += ".exe"
msg += " #%d..." % (i + 1)
print msg,
serverPipes[i] = os.popen(TestUtil.createCmd(mono, server) + TestUtil.serverOptions + " %d" % (base + i))
TestUtil.getServerPid(serverPipes[i])
TestUtil.getAdapterReady(serverPipes[i])
print "ok"
ports = ""
for i in range(0, num):
ports = "%s %d" % (ports, base + i)
print TestUtil.createMsg(mono, "client"),
clientPipe = os.popen(TestUtil.createCmd(mono, client) + TestUtil.clientOptions + " " + ports)
print "ok"
TestUtil.printOutputFromPipe(clientPipe)
clientStatus = TestUtil.closePipe(clientPipe)
serverStatus = None
#
# With ActiveState Python, the close() call raises an IOError if
# the server has died (whereas with Cygwin Python, no exception
# is raised. We swallow IOError here to avoid having the test
# claim that it failed when in fact it succeeded.
#
for i in range(0, num):
try:
serverStatus = serverStatus or TestUtil.closePipe(serverPipes[i])
except IOError, error:
pass
if clientStatus:
TestUtil.killServers()
sys.exit(1)
#
# Exit with status 0 even though some servers failed to shutdown
# properly. There's a problem which is occuring on Linux dual-processor
# machines, when ssl isn't enabled, and which cause some servers to
# segfault and abort. It's not clear what the problem is, and it's
# almost impossible to debug with the very poor information we get
# from the core file (ulimit -c unlimited to enable core files on
# Linux).
#
# For C#, we also have the problem that terminating a server with
# Process.Kill() is the only way to simulate an abort, but the
# server then returns non-zero exit status.
#
if serverStatus:
TestUtil.killServers()
# sys.exit(1)
# if TestUtil.isWin32():
# sys.exit(1)
# else:
# sys.exit(0)
sys.exit(0)
|