1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-21 21:50:00 -05:00

fix(WebSocket): no panic on failed connect + handle promise rejection via error event (#7437)

This commit is contained in:
Luca Casonato 2020-09-13 11:52:20 +02:00 committed by GitHub
parent 82d0f7ec84
commit daa780e2cf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 42 additions and 8 deletions

View file

@ -1489,7 +1489,7 @@ interface WebSocket extends EventTarget {
*/
readonly extensions: string;
onclose: ((this: WebSocket, ev: CloseEvent) => any) | null;
onerror: ((this: WebSocket, ev: Event) => any) | null;
onerror: ((this: WebSocket, ev: Event | ErrorEvent) => any) | null;
onmessage: ((this: WebSocket, ev: MessageEvent) => any) | null;
onopen: ((this: WebSocket, ev: Event) => any) | null;
/**

View file

@ -56,13 +56,12 @@ pub async fn op_ws_create(
cli_state.check_net_url(&url::Url::parse(&args.url)?)?;
cli_state.global_state.flags.ca_file.clone()
};
let uri: Uri = args.url.parse().unwrap();
let uri: Uri = args.url.parse()?;
let request = Request::builder()
.method(Method::GET)
.uri(&uri)
.header("Sec-WebSocket-Protocol", args.protocols)
.body(())
.unwrap();
.body(())?;
let domain = &uri.host().unwrap().to_string();
let port = &uri.port_u16().unwrap_or(match uri.scheme_str() {
Some("wss") => 443,
@ -100,7 +99,12 @@ pub async fn op_ws_create(
};
let (stream, response): (WsStream, Response) =
client_async(request, socket).await.unwrap();
client_async(request, socket).await.map_err(|err| {
ErrBox::type_error(format!(
"failed to connect to WebSocket: {}",
err.to_string()
))
})?;
let mut state = state.borrow_mut();
let rid = state

View file

@ -100,6 +100,14 @@
this.onclose?.(closeEvent);
this.dispatchEvent(closeEvent);
}
}).catch((err) => {
const event = new ErrorEvent(
"error",
{ error: err, message: err.toString() },
);
event.target = this;
this.onerror?.(event);
this.dispatchEvent(event);
});
}

View file

@ -403,7 +403,9 @@ fn fmt_stdin_error() {
}
// Warning: this test requires internet access.
// TODO(#7412): reenable. test is flaky
#[test]
#[ignore]
fn upgrade_in_tmpdir() {
let temp_dir = TempDir::new().unwrap();
let exe_path = temp_dir.path().join("deno");
@ -423,7 +425,9 @@ fn upgrade_in_tmpdir() {
}
// Warning: this test requires internet access.
// TODO(#7412): reenable. test is flaky
#[test]
#[ignore]
fn upgrade_with_space_in_path() {
let temp_dir = tempfile::Builder::new()
.prefix("directory with spaces")
@ -473,7 +477,9 @@ fn upgrade_with_version_in_tmpdir() {
}
// Warning: this test requires internet access.
// TODO(#7412): reenable. test is flaky
#[test]
#[ignore]
fn upgrade_with_out_in_tmpdir() {
let temp_dir = TempDir::new().unwrap();
let exe_path = temp_dir.path().join("deno");

View file

@ -1,5 +1,6 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import {
assert,
assertEquals,
assertThrows,
createResolvable,
@ -135,18 +136,33 @@ Deno.test("echo string", async () => {
});
Deno.test("echo string tls", async () => {
const promise = createResolvable();
const promise1 = createResolvable();
const promise2 = createResolvable();
const ws = new WebSocket("wss://localhost:4243");
ws.onerror = (): void => fail();
ws.onopen = (): void => ws.send("foo");
ws.onmessage = (e): void => {
assertEquals(e.data, "foo");
ws.close();
promise1.resolve();
};
ws.onclose = (): void => {
promise.resolve();
promise2.resolve();
};
await promise;
await promise1;
await promise2;
});
Deno.test("websocket error", async () => {
const promise1 = createResolvable();
const ws = new WebSocket("wss://localhost:4242");
ws.onopen = () => fail();
ws.onerror = (err): void => {
assert(err instanceof ErrorEvent);
assertEquals(err.message, "InvalidData: received corrupt message");
promise1.resolve();
};
await promise1;
});
Deno.test("echo blob with binaryType blob", async () => {