1
|
1 |
|
import sys |
2
|
1 |
|
import time |
3
|
|
|
|
4
|
1 |
|
from ppp_libmodule.tests import PPPTestCase |
5
|
1 |
|
from ppp_libmodule.http import HttpRequestHandler |
6
|
1 |
|
from ppp_libmodule import shortcuts |
7
|
|
|
|
8
|
1 |
|
from ppp_datamodel.nodes import Triple as T |
9
|
1 |
|
from ppp_datamodel.nodes import Missing as M |
10
|
1 |
|
from ppp_datamodel.nodes import Missing as R |
11
|
1 |
|
from ppp_datamodel.nodes import List as L |
12
|
1 |
|
from ppp_datamodel.communication import Response, TraceItem |
13
|
|
|
|
14
|
1 |
|
def predicate(node): |
15
|
1 |
|
if node == T(M(), M(), M()): |
16
|
1 |
|
return R('foo') |
17
|
1 |
|
elif node == R('foo'): |
18
|
1 |
|
return R('bar') |
19
|
1 |
|
elif node == M(): |
20
|
|
|
return node |
21
|
1 |
|
elif node == L([]): |
22
|
1 |
|
return node |
23
|
|
|
else: |
24
|
|
|
assert False, node |
25
|
|
|
|
26
|
1 |
|
class RequestHandler: |
27
|
1 |
|
def __init__(self, request): |
28
|
1 |
|
self.request = request |
29
|
|
|
|
30
|
1 |
|
def answer(self): |
31
|
1 |
|
tree = self.request.tree.traverse(predicate) |
32
|
1 |
|
if tree != self.request.tree: |
33
|
|
|
# If we have modified the tree, it is relevant to return it |
34
|
1 |
|
return [shortcuts.build_answer(self.request, tree, {}, 'test')] |
35
|
|
|
else: |
36
|
|
|
# Otherwise, we have nothing interesting to say. |
37
|
|
|
return [] |
38
|
|
|
|
39
|
1 |
|
def app(environ, start_response): |
40
|
|
|
"""Function called by the WSGI server.""" |
41
|
1 |
|
r = HttpRequestHandler(environ, start_response, RequestHandler).dispatch() |
42
|
1 |
|
return r |
43
|
|
|
|
44
|
1 |
|
class HttpTest(PPPTestCase(app)): |
45
|
1 |
|
def testWorking(self): |
46
|
1 |
|
t = T(M(), M(), M()) |
47
|
1 |
|
q = {'id': '1', 'language': 'en', 'tree': t.as_dict(), |
48
|
|
|
'measures': {}, 'trace': []} |
49
|
1 |
|
self.assertResponse(q, [Response('en', R('bar'), {}, |
50
|
|
|
[TraceItem('test', R('bar'), {})])]) |
51
|
|
|
|
52
|
1 |
|
def _get_test_times_trace_item(self): |
53
|
1 |
|
t = T(M(), M(), M()) |
54
|
1 |
|
q = {'id': '1', 'language': 'en', 'tree': t.as_dict(), |
55
|
|
|
'measures': {}, 'trace': []} |
56
|
1 |
|
responses = self.request(q) |
57
|
1 |
|
self.assertEqual(len(responses), 1, responses) |
58
|
1 |
|
response = responses[0] |
59
|
1 |
|
self.assertEqual(len(response.trace), 1, response.trace) |
60
|
1 |
|
return response.trace[0] |
61
|
|
|
|
62
|
1 |
|
if sys.version_info >= (3, 3): |
63
|
1 |
|
def testTimes(self): |
64
|
1 |
|
trace_item = self._get_test_times_trace_item() |
65
|
|
|
|
66
|
1 |
|
self.assertEqual(set(trace_item.times), {'start', 'end', 'cpu'}) |
67
|
|
|
|
68
|
1 |
|
self.assertGreater(trace_item.times['cpu'], 0.) |
69
|
|
|
# The following may fail on a very slow system. |
70
|
1 |
|
self.assertLess(trace_item.times['cpu'], 1.) |
71
|
1 |
|
self.assertAlmostEqual(trace_item.times['start'], time.time(), delta=1.) |
72
|
1 |
|
self.assertAlmostEqual(trace_item.times['end'], time.time(), delta=1.) |
73
|
|
|
else: |
74
|
|
|
def testTimes(self): |
75
|
|
|
trace_item = self._get_test_times_trace_item() |
76
|
|
|
|
77
|
|
|
self.assertEqual(set(trace_item.times), {'start', 'end'}) |
78
|
|
|
|
79
|
|
|
# The following may fail on a very slow system. |
80
|
|
|
self.assertAlmostEqual(trace_item.times['start'], time.time(), delta=1.) |
81
|
|
|
self.assertAlmostEqual(trace_item.times['end'], time.time(), delta=1.) |
82
|
|
|
|