1
0
Fork 0
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:
Leo K 2021-08-13 20:52:13 +02:00 committed by GitHub
parent c6e3f93ebb
commit 0c9d6cbb2a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 65 additions and 9 deletions

View file

@ -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() {

View 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;

View file

@ -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