-
Notifications
You must be signed in to change notification settings - Fork 50
/
Copy pathhttp_req.py
executable file
·105 lines (95 loc) · 3.78 KB
/
http_req.py
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
#!/usr/bin/env python
#-*-Mode:python;coding:utf-8;tab-width:4;c-basic-offset:4;indent-tabs-mode:()-*-
# ex: set ft=python fenc=utf-8 sts=4 ts=4 sw=4 et nomod:
#
# MIT License
#
# Copyright (c) 2011-2023 Michael Truog <mjtruog at protonmail dot com>
#
# Permission is hereby granted, free of charge, to any person obtaining a
# copy of this software and associated documentation files (the "Software"),
# to deal in the Software without restriction, including without limitation
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
# and/or sell copies of the Software, and to permit persons to whom the
# Software is furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
#
"""
HTTP Request Integration Test with Python
"""
from __future__ import print_function
import sys
import threading
import traceback
from cloudi import API, TerminateException
class Task(threading.Thread):
"""
http_req thread task
"""
def __init__(self, thread_index, name, api_class, terminate_exception):
threading.Thread.__init__(self)
self.__api = None
self.__thread_index = thread_index
self.__name = name
self.__api_class = api_class
self.__terminate_exception = terminate_exception
def run(self):
"""
run the http_req thread
"""
# pylint: disable=broad-except
try:
self.__api = self.__api_class(self.__thread_index)
if self.__name == 'python':
assert self.__api.subscribe_count('python.xml/get') == 0
self.__api.subscribe(self.__name + '.xml/get', self.__request)
if self.__name == 'python':
assert self.__api.subscribe_count('python.xml/get') == 1
result = self.__api.poll()
assert result is False
except self.__terminate_exception:
pass
except Exception:
traceback.print_exc(file=sys.stderr)
print('terminate http_req %s' % self.__name)
def __request(self, request_type, name, pattern, request_info, request,
timeout, priority, trans_id, source):
# pylint: disable=unused-argument
# pylint: disable=too-many-arguments
http_qs = API.info_key_value_parse(request)
value = http_qs.get(b'value', None)
if value is None:
response = """\
<http_test><error>no value specified</error></http_test>"""
else:
if isinstance(value, list):
value = value[0]
response = """\
<http_test><value>%d</value></http_test>""" % (int(value),)
response_info = API.info_key_value_new({
b'content-type': b'text/xml; charset=utf-8',
})
self.__api.return_(request_type, name, pattern,
response_info, response.encode('utf-8'),
timeout, trans_id, source)
def _main():
thread_count = API.thread_count()
assert thread_count >= 1
threads = [Task(thread_index, 'python', API, TerminateException)
for thread_index in range(thread_count)]
for thread in threads:
thread.start()
for thread in threads:
thread.join()
if __name__ == '__main__':
_main()