use std::io::{Read, Write};
use std::net::{TcpStream, TcpListener};
use std::time::Duration;
use std::thread;
use lightws::endpoint::Endpoint;
use lightws::role::{Client, Server};
use log::debug;
const ADDR: &str = "127.0.0.1:10000";
const HOST: &str = "www.example.com";
const PATH: &str = "/ws";
const ECHO_DATA: &[u8] = b"ECHO ECHO ECHO!";
macro_rules! gets {
($b: expr) => {
std::str::from_utf8($b).unwrap()
};
}
#[test]
fn sync_echo() {
env_logger::init();
let lis = TcpListener::bind(ADDR).unwrap();
let t1 = thread::spawn(move || {
let mut buf = vec![0u8; 1024];
let (tcp, _) = lis.accept().unwrap();
debug!("server: tcp accepted!");
let mut ws = Endpoint::<_, Server>::accept(tcp, &mut buf, HOST, PATH).unwrap();
debug!("server: websocket accepted!");
loop {
let n = ws.read(&mut buf).unwrap();
if n == 0 && ws.is_read_end() {
debug!("server: close");
break;
}
debug!("server: echo..");
let _ = ws.write(&buf[..n]).unwrap();
}
});
let t2 = thread::spawn(|| {
let mut buf = vec![0u8; 1024];
debug!("client: sleep 500ms..");
thread::sleep(Duration::from_millis(500));
let tcp = TcpStream::connect(ADDR).unwrap();
debug!("client: tcp connected!");
let mut ws = Endpoint::<_, Client>::connect(tcp, &mut buf, HOST, PATH).unwrap();
debug!("client: websocket connected!");
for i in 1..=5 {
debug!("client: send[{}]..", i);
let n = ws.write(ECHO_DATA).unwrap();
assert_eq!(n, ECHO_DATA.len());
let n = ws.read(&mut buf).unwrap();
debug!("client: receive message: {}", gets!(&buf[..n]));
assert_eq!(n, ECHO_DATA.len());
assert_eq!(&buf[..n], ECHO_DATA);
}
debug!("client: close");
});
t1.join().unwrap();
t2.join().unwrap();
}