tungstenite-rs/examples/autobahn-client.rs

54 lines
1.4 KiB
Rust
Raw Normal View History

2019-08-26 17:00:41 +00:00
use log::*;
2016-12-21 23:42:09 +00:00
use url::Url;
use tungstenite::{connect, Error, Message, Result};
2016-12-21 23:42:09 +00:00
2019-11-24 14:20:19 +00:00
const AGENT: &str = "Tungstenite";
2016-12-21 23:42:09 +00:00
fn get_case_count() -> Result<u32> {
2019-08-26 17:00:41 +00:00
let (mut socket, _) = connect(Url::parse("ws://localhost:9001/getCaseCount").unwrap())?;
let msg = socket.read()?;
socket.close(None)?;
2016-12-21 23:42:09 +00:00
Ok(msg.into_text()?.parse::<u32>().unwrap())
}
fn update_reports() -> Result<()> {
let (mut socket, _) = connect(
Url::parse(&format!("ws://localhost:9001/updateReports?agent={}", AGENT)).unwrap(),
)?;
socket.close(None)?;
2016-12-21 23:42:09 +00:00
Ok(())
}
fn run_test(case: u32) -> Result<()> {
info!("Running test case {}", case);
let case_url =
Url::parse(&format!("ws://localhost:9001/runCase?case={}&agent={}", case, AGENT)).unwrap();
let (mut socket, _) = connect(case_url)?;
2016-12-21 23:42:09 +00:00
loop {
match socket.read()? {
2019-08-26 17:00:41 +00:00
msg @ Message::Text(_) | msg @ Message::Binary(_) => {
socket.send(msg)?;
}
2021-11-02 14:05:03 +00:00
Message::Ping(_) | Message::Pong(_) | Message::Close(_) | Message::Frame(_) => {}
}
2016-12-21 23:42:09 +00:00
}
}
fn main() {
env_logger::init();
2016-12-21 23:42:09 +00:00
let total = get_case_count().unwrap();
2019-11-24 14:20:19 +00:00
for case in 1..=total {
2016-12-21 23:42:09 +00:00
if let Err(e) = run_test(case) {
match e {
Error::ConnectionClosed | Error::Protocol(_) | Error::Utf8 => (),
err => error!("test: {}", err),
2016-12-21 23:42:09 +00:00
}
}
}
update_reports().unwrap();
}