use std::net::SocketAddr;
use clap::{Parser, ValueEnum};
use client::run_client;
use hydroflow::util::{bind_udp_bytes, ipv4_resolve};
use server::run_server;
mod client;
mod protocol;
mod server;
#[derive(Clone, ValueEnum, Debug)]
enum Role {
Client,
Server,
}
#[derive(Parser, Debug, Clone, ValueEnum)]
enum GraphType {
Mermaid,
Dot,
Json,
}
#[derive(Parser, Debug)]
struct Opts {
#[clap(value_enum, long)]
role: Role,
#[clap(long, value_parser = ipv4_resolve)]
addr: Option<SocketAddr>,
#[clap(long, value_parser = ipv4_resolve)]
server_addr: Option<SocketAddr>,
#[clap(value_enum, long)]
graph: Option<GraphType>,
}
#[hydroflow::main]
async fn main() {
let opts = Opts::parse();
let addr = opts
.addr
.unwrap_or_else(|| ipv4_resolve("localhost:0").unwrap());
let (outbound, inbound, addr) = bind_udp_bytes(addr).await;
println!("Listening on {:?}", addr);
match opts.role {
Role::Server => {
run_server(outbound, inbound, opts).await;
}
Role::Client => {
run_client(outbound, inbound, opts, addr).await;
}
}
}
#[test]
fn test() {
use std::io::Write;
use hydroflow::util::{run_cargo_example, wait_for_process_output};
let (_server, _, mut server_stdout) =
run_cargo_example("vector_clock", "--role server --addr 127.0.0.1:11053");
let (_client1, mut client1_stdin, mut client1_stdout) = run_cargo_example(
"vector_clock",
"--role client --server-addr 127.0.0.1:11053",
);
let (_client2, mut client2_stdin, mut client2_stdout) = run_cargo_example(
"vector_clock",
"--role client --server-addr 127.0.0.1:11053",
);
let mut server_output = String::new();
wait_for_process_output(&mut server_output, &mut server_stdout, "Server live!");
let mut client1_output = String::new();
wait_for_process_output(&mut client1_output, &mut client1_stdout, "Client live!");
let mut client2_output = String::new();
wait_for_process_output(&mut client2_output, &mut client2_stdout, "Client live!");
client1_stdin.write_all(b"Hello1\n").unwrap();
wait_for_process_output(
&mut client1_output,
&mut client1_stdout,
r#"payload: "Hello1", vc: .*"127.0.0.1:11053": Max\(1\).*from 127.0.0.1:11053"#,
);
client2_stdin.write_all(b"Hello2\n").unwrap();
wait_for_process_output(
&mut client2_output,
&mut client2_stdout,
r#"payload: "Hello2", vc: .*"127.0.0.1:11053": Max\(2\).*from 127.0.0.1:11053"#,
);
}