From 3f5265b21ec578e543d09cdc9d8b19d9655aebd9 Mon Sep 17 00:00:00 2001 From: Casper Beyer Date: Tue, 16 Feb 2021 09:10:59 +0800 Subject: [PATCH] fix: align btoa to spec (#9053) --- cli/tests/unit/text_encoding_test.ts | 2 +- op_crates/web/08_text_encoding.js | 11 ++++++++--- tools/wpt/expectation.json | 3 +++ 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/cli/tests/unit/text_encoding_test.ts b/cli/tests/unit/text_encoding_test.ts index 58905157a9..c7c07f9373 100644 --- a/cli/tests/unit/text_encoding_test.ts +++ b/cli/tests/unit/text_encoding_test.ts @@ -69,7 +69,7 @@ unitTest(function btoaFailed(): void { const text = "你好"; assertThrows(() => { btoa(text); - }, TypeError); + }, DOMException); }); unitTest(function textDecoder2(): void { diff --git a/op_crates/web/08_text_encoding.js b/op_crates/web/08_text_encoding.js index c9d7087407..c3e622c994 100644 --- a/op_crates/web/08_text_encoding.js +++ b/op_crates/web/08_text_encoding.js @@ -26,6 +26,7 @@ "use strict"; ((window) => { + const webidl = window.__bootstrap.webidl; const core = Deno.core; const CONTINUE = null; @@ -124,13 +125,17 @@ } function btoa(s) { + s = webidl.converters.DOMString(s, { + prefix: "Failed to execute 'bota'", + context: "Argument 1", + }); const byteArray = []; for (let i = 0; i < s.length; i++) { const charCode = s[i].charCodeAt(0); if (charCode > 0xff) { - throw new TypeError( - "The string to be encoded contains characters " + - "outside of the Latin1 range.", + throw new DOMException( + "The string to be encoded contains characters outside of the Latin1 range.", + "InvalidCharacterError", ); } byteArray.push(charCode); diff --git a/tools/wpt/expectation.json b/tools/wpt/expectation.json index 00f0040486..b2df7e407b 100644 --- a/tools/wpt/expectation.json +++ b/tools/wpt/expectation.json @@ -1041,6 +1041,9 @@ }, "html": { "webappapis": { + "atob": { + "base64.any.js": true + }, "timers": { "cleartimeout-clearinterval.any.js": true, "missing-timeout-setinterval.any.js": true,