forked from vitalik/django-ninja-benchmarks
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_test.py
100 lines (74 loc) · 2.49 KB
/
run_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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
import time
import re
import os
import sys
import subprocess
C1_FRAMEWORKS = [
'flask_marshmallow_uwsgi',
'drf_uwsgi',
'ninja_uwsgi',
]
CONCURRENT_FRAMEWORKS = [
'flask_marshmallow_uwsgi',
'drf_uwsgi',
'ninja_uvicorn',
]
class FrameworkService:
def __init__(self, name, workers=1):
self.name = name
self.workers = workers
def __enter__(self):
os.system(f'WORKERS={self.workers} docker-compose up -d network_service')
os.system(f'WORKERS={self.workers} docker-compose up -d {self.name}')
time.sleep(5)
def __exit__(self, *a, **kw):
os.system(f'WORKERS={self.workers} docker-compose down')
def benchmark(url, concurency, count, payload=None):
cmd = ['ab', '-c', f'{concurency}', '-n', f'{count}']
if payload:
cmd += ['-l', '-p', payload, '-T', 'application/json']
cmd += [url]
print('> ', ' '.join(cmd))
result = subprocess.run(cmd, stdout=subprocess.PIPE)
output = result.stdout.decode('utf-8')
assert result.returncode == 0, output
return parse_benchmark(output)
def parse_benchmark(output: str):
# print(output)
rps = re.findall(r'Requests per second: \s+(.*?)\s', output)[0]
p50 = re.findall(r'\s+50%\s+(\d+)', output)[0]
p99 = re.findall(r'\s+99%\s+(\d+)', output)[0]
return (rps, p50, p99)
# print()
# re.findall(r'')
def preheat():
benchmark('http://127.0.0.1:8000/api/create', 1, 5, 'payload.json')
benchmark('http://127.0.0.1:8000/api/iojob', 1, 5)
def run_c1_test():
return benchmark('http://127.0.0.1:8000/api/create', 1, 1000, 'payload.json')
WORKERS_CASES = list(range(1, 25)) # [14, 15, 16, 17, 18, 19, 20]
def test_concurrent(name):
results = {}
for workers in WORKERS_CASES:
with FrameworkService(name, workers):
preheat()
res = benchmark('http://127.0.0.1:8000/api/iojob', 50, 200)
results[workers] = res
return results
def main():
os.system(f'docker-compose build')
os.system(f'docker-compose down')
results = {}
for framework in CONCURRENT_FRAMEWORKS:
results[framework] = test_concurrent(framework)
print('Framework :', end='')
for w in WORKERS_CASES:
print(f'{w:>9}', end='')
print('')
for framework, results in sorted(results.items()):
print(f'{framework:<23} :', end='')
for w in WORKERS_CASES:
print(f'{results[w][0]:>9}', end='')
print('')
if __name__ == '__main__':
main()