-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoptimization_test.py
85 lines (72 loc) · 1.63 KB
/
optimization_test.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
import asyncio
import os
import random
import secrets
import timeit
import traceback
from statistics import fmean
from gql import Client, gql
from gql.transport.aiohttp import AIOHTTPTransport
NUMBER_OF_REQUESTS = 100
TEST_URL = os.getenv('APP_INTEGRATION_TEST_HOST')
QUERY = """
query GetTaskData {
workflows {
active {
iid
tasks {
iid
tid
status
data {
dataId
type
order
label
data
variant
encrypted
validators {
type
constraint
}
}
}
}
}
}
"""
async def main():
session_id = secrets.token_hex()
print(f'Starting test {session_id}')
query = gql(QUERY)
transport = AIOHTTPTransport(
url=TEST_URL,
headers={'session_id': session_id},
)
client = Client(
transport=transport,
execute_timeout=300,
)
times = []
try:
async with client as session:
for _ in range(NUMBER_OF_REQUESTS):
await asyncio.sleep(random.random())
t1 = timeit.default_timer()
await session.execute(query)
t2 = timeit.default_timer()
result = t2 - t1
times.append(result)
except Exception:
print('Error!')
traceback.print_exc()
await client.transport.close()
print(times)
if times:
avgtime = fmean(times)
print(f'Finished with {session_id}, avg time {avgtime}')
else:
print('Could not get data points')
if __name__ == '__main__':
asyncio.run(main())