0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-31 09:14:20 -04:00
denoland-deno/tools/http_benchmark.py

68 lines
1.8 KiB
Python
Raw Normal View History

2018-10-15 16:44:35 -04:00
#!/usr/bin/env python
2018-10-19 15:25:29 -04:00
# Copyright 2018 the Deno authors. All rights reserved. MIT license.
2018-10-15 16:44:35 -04:00
import os
import sys
import util
import time
import subprocess
ADDR = "127.0.0.1:4544"
DURATION = "10s"
def deno_http_benchmark(deno_exe):
2018-10-15 16:44:35 -04:00
deno_cmd = [deno_exe, "--allow-net", "tests/http_bench.ts", ADDR]
print "http_benchmark testing DENO."
return run(deno_cmd)
2018-10-15 16:44:35 -04:00
def node_http_benchmark():
node_cmd = ["node", "tools/node_http.js", ADDR.split(":")[1]]
2018-10-15 16:44:35 -04:00
print "http_benchmark testing NODE."
return run(node_cmd)
def node_tcp_benchmark():
node_cmd = ["node", "tools/node_tcp.js", ADDR.split(":")[1]]
print "http_benchmark testing node_tcp.js"
return run(node_cmd)
def hyper_http_benchmark(hyper_hello_exe):
hyper_cmd = [hyper_hello_exe, ADDR.split(":")[1]]
print "http_benchmark testing RUST hyper."
return run(hyper_cmd)
2018-10-15 16:44:35 -04:00
def http_benchmark(deno_exe, hyper_hello_exe):
r = {}
# TODO Rename to "deno_tcp"
r["deno"] = deno_http_benchmark(deno_exe)
r["node"] = node_http_benchmark()
r["node_tcp"] = node_tcp_benchmark()
r["hyper"] = hyper_http_benchmark(hyper_hello_exe)
return r
2018-10-15 16:44:35 -04:00
def run(server_cmd):
# Run deno echo server in the background.
server = subprocess.Popen(server_cmd)
time.sleep(5) # wait for server to wake up. TODO racy.
try:
2018-10-19 19:15:14 -04:00
cmd = "third_party/wrk/%s/wrk -d %s http://%s/" % (util.platform(),
DURATION, ADDR)
2018-10-15 16:44:35 -04:00
print cmd
output = subprocess.check_output(cmd, shell=True)
req_per_sec = util.parse_wrk_output(output)
print output
return req_per_sec
finally:
server.kill()
if __name__ == '__main__':
if len(sys.argv) < 2:
2018-10-19 08:44:18 -04:00
print "Usage ./tools/http_benchmark.py out/debug/deno"
2018-10-15 16:44:35 -04:00
sys.exit(1)
deno_http_benchmark(sys.argv[1])