summaryrefslogtreecommitdiff
path: root/cli/bench/deno_tcp_proxy.ts
diff options
context:
space:
mode:
authorValentin Anger <syrupthinker@gryphno.de>2020-08-28 15:03:50 +0200
committerGitHub <noreply@github.com>2020-08-28 09:03:50 -0400
commit31f32ed8c4082d36ad2a4ea460366c0d57a5ddbc (patch)
tree2b60111cd53dd4034d1a92ee8caff89d164b7d2d /cli/bench/deno_tcp_proxy.ts
parent3d23208019a2c9faaf265ff13ad59f2d04f10079 (diff)
Move benchmarks to Rust (#7134)
All benchmarks are done in Rust and can be invoked with `cargo bench`. Currently this has it's own "harness" that behaves like `./tools/benchmark.py` did. Because of this tests inside `cli/bench` are currently not run. This should be switched to the language provided harness once the `#[bench]` attribute has been stabilized.
Diffstat (limited to 'cli/bench/deno_tcp_proxy.ts')
-rw-r--r--cli/bench/deno_tcp_proxy.ts30
1 files changed, 30 insertions, 0 deletions
diff --git a/cli/bench/deno_tcp_proxy.ts b/cli/bench/deno_tcp_proxy.ts
new file mode 100644
index 000000000..db693b690
--- /dev/null
+++ b/cli/bench/deno_tcp_proxy.ts
@@ -0,0 +1,30 @@
+// Used for benchmarking Deno's tcp proxy performance.
+const addr = Deno.args[0] || "127.0.0.1:4500";
+const originAddr = Deno.args[1] || "127.0.0.1:4501";
+
+const [hostname, port] = addr.split(":");
+const [originHostname, originPort] = originAddr.split(":");
+
+const listener = Deno.listen({ hostname, port: Number(port) });
+
+async function handle(conn: Deno.Conn): Promise<void> {
+ const origin = await Deno.connect({
+ hostname: originHostname,
+ port: Number(originPort),
+ });
+ try {
+ await Promise.all([Deno.copy(conn, origin), Deno.copy(origin, conn)]);
+ } catch (err) {
+ if (err.message !== "read error" && err.message !== "write error") {
+ throw err;
+ }
+ } finally {
+ conn.close();
+ origin.close();
+ }
+}
+
+console.log(`Proxy listening on http://${addr}/`);
+for await (const conn of listener) {
+ handle(conn);
+}