mirror of https://github.com/fafhrd91/actix-web
add tests for WsResponseBuilder
This commit is contained in:
parent
988e85bb88
commit
8fc3b9522a
|
@ -1,4 +1,5 @@
|
||||||
use actix::prelude::*;
|
use actix::prelude::*;
|
||||||
|
use actix_http::ws::Codec;
|
||||||
use actix_web::{test, web, App, HttpRequest};
|
use actix_web::{test, web, App, HttpRequest};
|
||||||
use actix_web_actors::*;
|
use actix_web_actors::*;
|
||||||
use bytes::Bytes;
|
use bytes::Bytes;
|
||||||
|
@ -26,16 +27,10 @@ impl StreamHandler<Result<ws::Message, ws::ProtocolError>> for Ws {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[actix_rt::test]
|
const MAX_FRAME_SIZE: usize = 10_000;
|
||||||
async fn test_simple() {
|
const DEFAULT_FRAME_SIZE: usize = 10;
|
||||||
let mut srv = test::start(|| {
|
|
||||||
App::new().service(web::resource("/").to(
|
|
||||||
|req: HttpRequest, stream: web::Payload| async move {
|
|
||||||
ws::start(Ws, &req, stream)
|
|
||||||
},
|
|
||||||
))
|
|
||||||
});
|
|
||||||
|
|
||||||
|
async fn common_test_code(mut srv: test::TestServer, frame_size: usize) {
|
||||||
// client service
|
// client service
|
||||||
let mut framed = srv.ws().await.unwrap();
|
let mut framed = srv.ws().await.unwrap();
|
||||||
framed.send(ws::Message::Text("text".into())).await.unwrap();
|
framed.send(ws::Message::Text("text".into())).await.unwrap();
|
||||||
|
@ -43,12 +38,13 @@ async fn test_simple() {
|
||||||
let item = framed.next().await.unwrap().unwrap();
|
let item = framed.next().await.unwrap().unwrap();
|
||||||
assert_eq!(item, ws::Frame::Text(Bytes::from_static(b"text")));
|
assert_eq!(item, ws::Frame::Text(Bytes::from_static(b"text")));
|
||||||
|
|
||||||
|
let bytes = Bytes::from(vec![0; frame_size]);
|
||||||
framed
|
framed
|
||||||
.send(ws::Message::Binary("text".into()))
|
.send(ws::Message::Binary(bytes.clone()))
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let item = framed.next().await.unwrap().unwrap();
|
let item = framed.next().await.unwrap().unwrap();
|
||||||
assert_eq!(item, ws::Frame::Binary(Bytes::from_static(b"text")));
|
assert_eq!(item, ws::Frame::Binary(bytes));
|
||||||
|
|
||||||
framed.send(ws::Message::Ping("text".into())).await.unwrap();
|
framed.send(ws::Message::Ping("text".into())).await.unwrap();
|
||||||
let item = framed.next().await.unwrap().unwrap();
|
let item = framed.next().await.unwrap().unwrap();
|
||||||
|
@ -62,3 +58,107 @@ async fn test_simple() {
|
||||||
let item = framed.next().await.unwrap().unwrap();
|
let item = framed.next().await.unwrap().unwrap();
|
||||||
assert_eq!(item, ws::Frame::Close(Some(ws::CloseCode::Normal.into())));
|
assert_eq!(item, ws::Frame::Close(Some(ws::CloseCode::Normal.into())));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_builder() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::WsResponseBuilder::new(Ws, &req, stream).start()
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, DEFAULT_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_builder_with_frame_size() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::WsResponseBuilder::new(Ws, &req, stream)
|
||||||
|
.frame_size(MAX_FRAME_SIZE)
|
||||||
|
.start()
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, MAX_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_builder_with_codec() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::WsResponseBuilder::new(Ws, &req, stream)
|
||||||
|
.codec(Codec::new())
|
||||||
|
.start()
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, DEFAULT_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_builder_with_protocols() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::WsResponseBuilder::new(Ws, &req, stream)
|
||||||
|
.protocols(&["A", "B"])
|
||||||
|
.start()
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, DEFAULT_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_builder_full() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::WsResponseBuilder::new(Ws, &req, stream)
|
||||||
|
.frame_size(MAX_FRAME_SIZE)
|
||||||
|
.codec(Codec::new())
|
||||||
|
.protocols(&["A", "B"])
|
||||||
|
.start()
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, MAX_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_builder_with_codec_and_frame_size() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::WsResponseBuilder::new(Ws, &req, stream)
|
||||||
|
.codec(Codec::new())
|
||||||
|
.frame_size(MAX_FRAME_SIZE)
|
||||||
|
.start()
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, DEFAULT_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_simple() {
|
||||||
|
let srv = test::start(|| {
|
||||||
|
App::new().service(web::resource("/").to(
|
||||||
|
|req: HttpRequest, stream: web::Payload| async move {
|
||||||
|
ws::start(Ws, &req, stream)
|
||||||
|
},
|
||||||
|
))
|
||||||
|
});
|
||||||
|
|
||||||
|
common_test_code(srv, DEFAULT_FRAME_SIZE).await;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue