async-tungstenite/examples/autobahn-client.rs

61 lines
1.5 KiB
Rust

use futures::StreamExt;
use log::*;
use async_tungstenite::{connect_async, tungstenite::Result};
use url::Url;
const AGENT: &'static str = "Tungstenite";
async fn get_case_count() -> Result<u32> {
let (mut socket, _) =
connect_async(Url::parse("ws://localhost:9001/getCaseCount").unwrap()).await?;
let msg = socket.next().await.unwrap()?;
socket.close(None).await?;
Ok(msg.into_text()?.parse::<u32>().unwrap())
}
async fn update_reports() -> Result<()> {
let (mut socket, _) = connect_async(
Url::parse(&format!(
"ws://localhost:9001/updateReports?agent={}",
AGENT
))
.unwrap(),
)
.await?;
socket.close(None).await?;
Ok(())
}
async fn run_test(case: u32) {
info!("Running test case {}", case);
let case_url = Url::parse(&format!(
"ws://localhost:9001/runCase?case={}&agent={}",
case, AGENT
))
.unwrap();
let (mut ws_stream, _) = connect_async(case_url).await.expect("Connect error");
while let Some(msg) = ws_stream.next().await {
let msg = msg.expect("Failed to get message");
if msg.is_text() || msg.is_binary() {
ws_stream.send(msg).await.expect("Write error");
}
}
}
async fn run() {
env_logger::init();
let total = get_case_count().await.unwrap();
for case in 1..(total + 1) {
run_test(case).await
}
update_reports().await.unwrap();
}
fn main() {
async_std::task::block_on(run());
}