blob: 0614992021a51d1236632b49d1dfb6146a34029e (
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
|
# **********************************************************************
#
# Copyright (c) 2003-2018 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 Ice, Test, sys, TestI
def test(b):
if not b:
raise RuntimeError('test assertion failed')
def allTests(helper, communicator):
ref = "factory:{0} -t 10000".format(helper.getTestEndpoint())
factory = Test.RemoteCommunicatorFactoryPrx.checkedCast(communicator.stringToProxy(ref))
sys.stdout.write("testing thread hooks... ")
sys.stdout.flush()
#
# Set the maximum size of the server-side thread pool in the new communicator to 5.
#
props = {}
props["Ice.ThreadPool.Server.SizeMax"] = "5"
com = factory.createCommunicator(props)
obj = com.getObject()
startCount = com.getThreadHookStartCount()
#
# Start 5 async invocations that sleep for a little while to force new threads to be created.
#
reqs = []
for i in range(0, 5):
reqs.append(obj.sleepAsync(100))
for f in reqs:
f.result()
#
# The remote thread hook should detect at least 4 more threads. There could be more for other Ice threads.
#
test(com.getThreadHookStartCount() - startCount >= 4)
test(com.getThreadStartCount() - startCount >= 4)
#
# Destroy the remote communicator to force the destruction of the thread pool.
#
com.destroy()
#
# Finally, make sure we detected the same number of stops as starts.
#
test(com.getThreadHookStopCount() == com.getThreadHookStartCount())
test(com.getThreadStopCount() == com.getThreadStartCount())
test(com.getThreadHookStartCount() == com.getThreadStartCount())
print("ok")
factory.shutdown()
|