mirror of
https://github.com/denoland/deno.git
synced 2025-01-18 20:04:03 -05:00
f5e46c9bf2
This looks like a massive PR, but it's only a move from cli/tests -> tests, and updates of relative paths for files. This is the first step towards aggregate all of the integration test files under tests/, which will lead to a set of integration tests that can run without the CLI binary being built. While we could leave these tests under `cli`, it would require us to keep a more complex directory structure for the various test runners. In addition, we have a lot of complexity to ignore various test files in the `cli` project itself (cargo publish exclusion rules, autotests = false, etc). And finally, the `tests/` folder will eventually house the `test_ffi`, `test_napi` and other testing code, reducing the size of the root repo directory. For easier review, the extremely large and noisy "move" is in the first commit (with no changes -- just a move), while the remainder of the changes to actual files is in the second commit.
45 lines
1.5 KiB
JavaScript
45 lines
1.5 KiB
JavaScript
// deno-fmt-ignore-file
|
|
// deno-lint-ignore-file
|
|
|
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
|
// Taken from Node 18.12.1
|
|
// This file is automatically generated by `tools/node_compat/setup.ts`. Do not modify this file manually.
|
|
|
|
'use strict';
|
|
|
|
// From: https://github.com/w3c/web-platform-tests/blob/fa9436d12c/encoding/textdecoder-streaming.html
|
|
// This is the part that can be run without ICU
|
|
|
|
require('../common');
|
|
|
|
const assert = require('assert');
|
|
|
|
const string =
|
|
'\x00123ABCabc\x80\xFF\u0100\u1000\uFFFD\uD800\uDC00\uDBFF\uDFFF';
|
|
const octets = {
|
|
'utf-8': [
|
|
0x00, 0x31, 0x32, 0x33, 0x41, 0x42, 0x43, 0x61, 0x62, 0x63, 0xc2, 0x80,
|
|
0xc3, 0xbf, 0xc4, 0x80, 0xe1, 0x80, 0x80, 0xef, 0xbf, 0xbd, 0xf0, 0x90,
|
|
0x80, 0x80, 0xf4, 0x8f, 0xbf, 0xbf],
|
|
'utf-16le': [
|
|
0x00, 0x00, 0x31, 0x00, 0x32, 0x00, 0x33, 0x00, 0x41, 0x00, 0x42, 0x00,
|
|
0x43, 0x00, 0x61, 0x00, 0x62, 0x00, 0x63, 0x00, 0x80, 0x00, 0xFF, 0x00,
|
|
0x00, 0x01, 0x00, 0x10, 0xFD, 0xFF, 0x00, 0xD8, 0x00, 0xDC, 0xFF, 0xDB,
|
|
0xFF, 0xDF]
|
|
};
|
|
|
|
Object.keys(octets).forEach((encoding) => {
|
|
for (let len = 1; len <= 5; ++len) {
|
|
const encoded = octets[encoding];
|
|
const decoder = new TextDecoder(encoding);
|
|
let out = '';
|
|
for (let i = 0; i < encoded.length; i += len) {
|
|
const sub = [];
|
|
for (let j = i; j < encoded.length && j < i + len; ++j)
|
|
sub.push(encoded[j]);
|
|
out += decoder.decode(new Uint8Array(sub), { stream: true });
|
|
}
|
|
out += decoder.decode();
|
|
assert.strictEqual(out, string);
|
|
}
|
|
});
|