mirror of
https://github.com/denoland/deno.git
synced 2024-12-31 11:34:15 -05:00
chore: add test for ws ping/pong (#18204)
This commit adds test for https://github.com/denoland/deno/issues/17761 which was fixed by https://github.com/denoland/deno/pull/17762. Verified that test fails on Deno 1.30.1
This commit is contained in:
parent
5c505316b3
commit
3a46a89e34
2 changed files with 51 additions and 0 deletions
|
@ -19,3 +19,20 @@ Deno.test(async function websocketConstructorTakeURLObjectAsParameter() {
|
||||||
};
|
};
|
||||||
await promise;
|
await promise;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// https://github.com/denoland/deno/pull/17762
|
||||||
|
// https://github.com/denoland/deno/issues/17761
|
||||||
|
Deno.test(async function websocketPingPong() {
|
||||||
|
const promise = deferred();
|
||||||
|
const ws = new WebSocket("ws://localhost:4245/");
|
||||||
|
assertEquals(ws.url, "ws://localhost:4245/");
|
||||||
|
ws.onerror = () => fail();
|
||||||
|
ws.onmessage = (e) => {
|
||||||
|
ws.send(e.data);
|
||||||
|
};
|
||||||
|
ws.onclose = () => {
|
||||||
|
promise.resolve();
|
||||||
|
};
|
||||||
|
await promise;
|
||||||
|
ws.close();
|
||||||
|
});
|
||||||
|
|
|
@ -85,6 +85,7 @@ const HTTPS_CLIENT_AUTH_PORT: u16 = 5552;
|
||||||
const WS_PORT: u16 = 4242;
|
const WS_PORT: u16 = 4242;
|
||||||
const WSS_PORT: u16 = 4243;
|
const WSS_PORT: u16 = 4243;
|
||||||
const WS_CLOSE_PORT: u16 = 4244;
|
const WS_CLOSE_PORT: u16 = 4244;
|
||||||
|
const WS_PING_PORT: u16 = 4245;
|
||||||
|
|
||||||
pub const PERMISSION_VARIANTS: [&str; 5] =
|
pub const PERMISSION_VARIANTS: [&str; 5] =
|
||||||
["read", "write", "env", "net", "run"];
|
["read", "write", "env", "net", "run"];
|
||||||
|
@ -330,6 +331,36 @@ async fn run_ws_server(addr: &SocketAddr) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fn run_ws_ping_server(addr: &SocketAddr) {
|
||||||
|
let listener = TcpListener::bind(addr).await.unwrap();
|
||||||
|
println!("ready: ws"); // Eye catcher for HttpServerCount
|
||||||
|
while let Ok((stream, _addr)) = listener.accept().await {
|
||||||
|
tokio::spawn(async move {
|
||||||
|
let ws_stream = accept_async(stream).await;
|
||||||
|
use futures::SinkExt;
|
||||||
|
use tokio_tungstenite::tungstenite::Message;
|
||||||
|
if let Ok(mut ws_stream) = ws_stream {
|
||||||
|
for i in 0..9 {
|
||||||
|
ws_stream.send(Message::Ping(vec![])).await.unwrap();
|
||||||
|
|
||||||
|
let msg = ws_stream.next().await.unwrap().unwrap();
|
||||||
|
assert_eq!(msg, Message::Pong(vec![]));
|
||||||
|
|
||||||
|
ws_stream
|
||||||
|
.send(Message::Text(format!("hello {}", i)))
|
||||||
|
.await
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
let msg = ws_stream.next().await.unwrap().unwrap();
|
||||||
|
assert_eq!(msg, Message::Text(format!("hello {}", i)));
|
||||||
|
}
|
||||||
|
|
||||||
|
ws_stream.close(None).await.unwrap();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async fn run_ws_close_server(addr: &SocketAddr) {
|
async fn run_ws_close_server(addr: &SocketAddr) {
|
||||||
let listener = TcpListener::bind(addr).await.unwrap();
|
let listener = TcpListener::bind(addr).await.unwrap();
|
||||||
while let Ok((stream, _addr)) = listener.accept().await {
|
while let Ok((stream, _addr)) = listener.accept().await {
|
||||||
|
@ -1486,6 +1517,8 @@ pub async fn run_all_servers() {
|
||||||
|
|
||||||
let ws_addr = SocketAddr::from(([127, 0, 0, 1], WS_PORT));
|
let ws_addr = SocketAddr::from(([127, 0, 0, 1], WS_PORT));
|
||||||
let ws_server_fut = run_ws_server(&ws_addr);
|
let ws_server_fut = run_ws_server(&ws_addr);
|
||||||
|
let ws_ping_addr = SocketAddr::from(([127, 0, 0, 1], WS_PING_PORT));
|
||||||
|
let ws_ping_server_fut = run_ws_ping_server(&ws_ping_addr);
|
||||||
let wss_addr = SocketAddr::from(([127, 0, 0, 1], WSS_PORT));
|
let wss_addr = SocketAddr::from(([127, 0, 0, 1], WSS_PORT));
|
||||||
let wss_server_fut = run_wss_server(&wss_addr);
|
let wss_server_fut = run_wss_server(&wss_addr);
|
||||||
let ws_close_addr = SocketAddr::from(([127, 0, 0, 1], WS_CLOSE_PORT));
|
let ws_close_addr = SocketAddr::from(([127, 0, 0, 1], WS_CLOSE_PORT));
|
||||||
|
@ -1503,6 +1536,7 @@ pub async fn run_all_servers() {
|
||||||
futures::join!(
|
futures::join!(
|
||||||
redirect_server_fut,
|
redirect_server_fut,
|
||||||
ws_server_fut,
|
ws_server_fut,
|
||||||
|
ws_ping_server_fut,
|
||||||
wss_server_fut,
|
wss_server_fut,
|
||||||
tls_server_fut,
|
tls_server_fut,
|
||||||
tls_client_auth_server_fut,
|
tls_client_auth_server_fut,
|
||||||
|
|
Loading…
Reference in a new issue