Files
orchid/stdio-perftest/src/main.rs

46 lines
1.3 KiB
Rust

use std::env::{self, args};
use std::io::{stdin, BufRead, BufReader, Write};
use std::process;
use std::time::SystemTime;
fn main() {
let is_child = env::args().any(|arg| arg == "child");
if is_child {
loop {
let mut input = String::new();
stdin().read_line(&mut input).unwrap();
if input == "ping\n" {
println!("pong");
} else if input == "\n" {
process::exit(0);
} else {
panic!("Unrecognized input {input:?}");
}
}
} else {
let steps = 1_000_000;
let mut child = process::Command::new(args().next().unwrap())
.arg("child")
.stdin(process::Stdio::piped())
.stdout(process::Stdio::piped())
.spawn()
.unwrap();
let mut bufr = BufReader::new(child.stdout.take().unwrap());
let mut child_stdin = child.stdin.take().unwrap();
let time = SystemTime::now();
for _ in 0..steps {
writeln!(child_stdin, "ping").unwrap();
let mut buf = String::new();
bufr.read_line(&mut buf).unwrap();
if buf != "pong\n" {
panic!("Unrecognized output {buf:?}")
}
}
writeln!(child_stdin).unwrap();
child.wait().unwrap();
let elapsed = time.elapsed().unwrap();
let avg = elapsed / steps;
println!("A roundtrip takes {avg:?}, {}ms on average", (avg.as_nanos() as f64) / 1_000_000f64);
}
}