mirror of
https://github.com/denoland/deno.git
synced 2024-12-24 08:09:08 -05:00
0ceb554343
* Native ES modules This is a major refactor of internal compiler. Before: JS and TS both were sent through the typescript compiler where their imports were parsed and handled. Both compiled to AMD JS and finally sent to V8 Now: JS is sent directly into V8. TS is sent through the typescript compiler, but tsc generates ES modules now instead of AMD. This generated JS is then dumped into V8. This should much faster for pure JS code. It may improve TS compilation speed. In the future this allows us to separate TS out of the runtime heap and into its own dedicated snapshot. This will result in a smaller runtime heap, and thus should be faster. Some tests were unfortunately disabled to ease landing this patch: 1. compiler_tests.ts which I intend to bring back in later commits. 2. Some text_encoding_test.ts tests which made the file invalid utf8. See PR for a discussion. Also worth noting that this is necessary to support WASM
67 lines
1.6 KiB
TypeScript
67 lines
1.6 KiB
TypeScript
// Copyright 2018 the Deno authors. All rights reserved. MIT license.
|
||
import { test, assert, assertEqual } from "./test_util.ts";
|
||
|
||
test(function atobSuccess() {
|
||
const text = "hello world";
|
||
const encoded = btoa(text);
|
||
assertEqual(encoded, "aGVsbG8gd29ybGQ=");
|
||
});
|
||
|
||
test(function btoaSuccess() {
|
||
const encoded = "aGVsbG8gd29ybGQ=";
|
||
const decoded = atob(encoded);
|
||
assertEqual(decoded, "hello world");
|
||
});
|
||
|
||
test(function btoaFailed() {
|
||
const text = "你好";
|
||
let err;
|
||
try {
|
||
btoa(text);
|
||
} catch (e) {
|
||
err = e;
|
||
}
|
||
assert(!!err);
|
||
assertEqual(err.name, "InvalidInput");
|
||
});
|
||
|
||
test(function textDecoder2() {
|
||
// prettier-ignore
|
||
const fixture = new Uint8Array([
|
||
0xf0, 0x9d, 0x93, 0xbd,
|
||
0xf0, 0x9d, 0x93, 0xae,
|
||
0xf0, 0x9d, 0x94, 0x81,
|
||
0xf0, 0x9d, 0x93, 0xbd
|
||
]);
|
||
const decoder = new TextDecoder();
|
||
assertEqual(decoder.decode(fixture), "𝓽𝓮𝔁𝓽");
|
||
});
|
||
|
||
test(function textDecoderASCII() {
|
||
const fixture = new Uint8Array([0x89, 0x95, 0x9f, 0xbf]);
|
||
const decoder = new TextDecoder("ascii");
|
||
assertEqual(decoder.decode(fixture), "‰•Ÿ¿");
|
||
});
|
||
|
||
test(function textDecoderErrorEncoding() {
|
||
let didThrow = false;
|
||
try {
|
||
const decoder = new TextDecoder("foo");
|
||
} catch (e) {
|
||
didThrow = true;
|
||
assertEqual(e.message, "The encoding label provided ('foo') is invalid.");
|
||
}
|
||
assert(didThrow);
|
||
});
|
||
|
||
test(function textEncoder2() {
|
||
const fixture = "𝓽𝓮𝔁𝓽";
|
||
const encoder = new TextEncoder();
|
||
// prettier-ignore
|
||
assertEqual(Array.from(encoder.encode(fixture)), [
|
||
0xf0, 0x9d, 0x93, 0xbd,
|
||
0xf0, 0x9d, 0x93, 0xae,
|
||
0xf0, 0x9d, 0x94, 0x81,
|
||
0xf0, 0x9d, 0x93, 0xbd
|
||
]);
|
||
});
|