From 31f32ed8c4082d36ad2a4ea460366c0d57a5ddbc Mon Sep 17 00:00:00 2001 From: Valentin Anger Date: Fri, 28 Aug 2020 15:03:50 +0200 Subject: 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. --- cli/bench/node_tcp_proxy.js | 68 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 cli/bench/node_tcp_proxy.js (limited to 'cli/bench/node_tcp_proxy.js') diff --git a/cli/bench/node_tcp_proxy.js b/cli/bench/node_tcp_proxy.js new file mode 100644 index 000000000..d693dc5c8 --- /dev/null +++ b/cli/bench/node_tcp_proxy.js @@ -0,0 +1,68 @@ +const net = require("net"); + +process.on("uncaughtException", function (error) { + console.error(error); +}); + +if (process.argv.length != 4) { + console.log("usage: %s ", process.argv[1]); + process.exit(); +} + +const localport = process.argv[2]; +const remoteport = process.argv[3]; + +const remotehost = "127.0.0.1"; + +const server = net.createServer(function (localsocket) { + const remotesocket = new net.Socket(); + + remotesocket.connect(remoteport, remotehost); + + localsocket.on("data", function (data) { + const flushed = remotesocket.write(data); + if (!flushed) { + localsocket.pause(); + } + }); + + remotesocket.on("data", function (data) { + const flushed = localsocket.write(data); + if (!flushed) { + remotesocket.pause(); + } + }); + + localsocket.on("drain", function () { + remotesocket.resume(); + }); + + remotesocket.on("drain", function () { + localsocket.resume(); + }); + + localsocket.on("close", function () { + remotesocket.end(); + }); + + remotesocket.on("close", function () { + localsocket.end(); + }); + + localsocket.on("error", function () { + localsocket.end(); + }); + + remotesocket.on("error", function () { + remotesocket.end(); + }); +}); + +server.listen(localport); + +console.log( + "redirecting connections from 127.0.0.1:%d to %s:%d", + localport, + remotehost, + remoteport, +); -- cgit v1.2.3