mirror of
https://github.com/denoland/deno.git
synced 2025-01-11 16:42:21 -05:00
fix(http/ws): support multiple options in connection header (#11675)
Co-authored-by: Luca Casonato <hello@lcas.dev>
This commit is contained in:
parent
c6e3f93ebb
commit
0c9d6cbb2a
3 changed files with 65 additions and 9 deletions
|
@ -684,6 +684,41 @@ fn websocketstream() {
|
||||||
assert!(status.success());
|
assert!(status.success());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn websocket_server_multi_field_connection_header() {
|
||||||
|
let script = util::testdata_path()
|
||||||
|
.join("websocket_server_multi_field_connection_header_test.ts");
|
||||||
|
let root_ca = util::testdata_path().join("tls/RootCA.pem");
|
||||||
|
let mut child = util::deno_cmd()
|
||||||
|
.arg("run")
|
||||||
|
.arg("--unstable")
|
||||||
|
.arg("--allow-net")
|
||||||
|
.arg("--cert")
|
||||||
|
.arg(root_ca)
|
||||||
|
.arg(script)
|
||||||
|
.stdout(std::process::Stdio::piped())
|
||||||
|
.spawn()
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
let stdout = child.stdout.as_mut().unwrap();
|
||||||
|
let mut buffer = [0; 5];
|
||||||
|
let read = stdout.read(&mut buffer).unwrap();
|
||||||
|
assert_eq!(read, 5);
|
||||||
|
let msg = std::str::from_utf8(&buffer).unwrap();
|
||||||
|
assert_eq!(msg, "READY");
|
||||||
|
|
||||||
|
let req = http::request::Builder::new()
|
||||||
|
.header(http::header::CONNECTION, "keep-alive, Upgrade")
|
||||||
|
.uri("ws://localhost:4319")
|
||||||
|
.body(())
|
||||||
|
.unwrap();
|
||||||
|
assert!(
|
||||||
|
deno_runtime::deno_websocket::tokio_tungstenite::tungstenite::connect(req)
|
||||||
|
.is_ok()
|
||||||
|
);
|
||||||
|
assert!(child.wait().unwrap().success());
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
#[cfg(not(windows))]
|
||||||
#[test]
|
#[test]
|
||||||
fn set_raw_should_not_panic_on_no_tty() {
|
fn set_raw_should_not_panic_on_no_tty() {
|
||||||
|
|
17
cli/tests/testdata/websocket_server_multi_field_connection_header_test.ts
vendored
Normal file
17
cli/tests/testdata/websocket_server_multi_field_connection_header_test.ts
vendored
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
import { deferred } from "../unit/test_util.ts";
|
||||||
|
|
||||||
|
const promise = deferred();
|
||||||
|
const listener = Deno.listen({ port: 4319 });
|
||||||
|
console.log("READY");
|
||||||
|
const conn = await listener.accept();
|
||||||
|
const httpConn = Deno.serveHttp(conn);
|
||||||
|
const { request, respondWith } = (await httpConn.nextRequest())!;
|
||||||
|
const {
|
||||||
|
response,
|
||||||
|
socket,
|
||||||
|
} = Deno.upgradeWebSocket(request);
|
||||||
|
socket.onerror = () => Deno.exit(1);
|
||||||
|
socket.onopen = () => socket.close();
|
||||||
|
socket.onclose = () => promise.resolve();
|
||||||
|
await respondWith(response);
|
||||||
|
await promise;
|
|
@ -268,18 +268,22 @@ async fn op_http_request_next(
|
||||||
|
|
||||||
let is_websocket_request = req
|
let is_websocket_request = req
|
||||||
.headers()
|
.headers()
|
||||||
.get(hyper::header::CONNECTION)
|
.get_all(hyper::header::CONNECTION)
|
||||||
.and_then(|v| {
|
.iter()
|
||||||
v.to_str().ok().map(|s| "Upgrade".eq_ignore_ascii_case(s))
|
.any(|v| {
|
||||||
|
v.to_str()
|
||||||
|
.map(|s| s.to_lowercase().contains("upgrade"))
|
||||||
|
.unwrap_or(false)
|
||||||
})
|
})
|
||||||
.unwrap_or(false)
|
|
||||||
&& req
|
&& req
|
||||||
.headers()
|
.headers()
|
||||||
.get(hyper::header::UPGRADE)
|
.get_all(hyper::header::UPGRADE)
|
||||||
.and_then(|v| {
|
.iter()
|
||||||
v.to_str().ok().map(|s| "websocket".eq_ignore_ascii_case(s))
|
.any(|v| {
|
||||||
})
|
v.to_str()
|
||||||
.unwrap_or(false);
|
.map(|s| s.to_lowercase().contains("websocket"))
|
||||||
|
.unwrap_or(false)
|
||||||
|
});
|
||||||
|
|
||||||
let has_body = if let Some(exact_size) = req.size_hint().exact() {
|
let has_body = if let Some(exact_size) = req.size_hint().exact() {
|
||||||
exact_size > 0
|
exact_size > 0
|
||||||
|
|
Loading…
Reference in a new issue