2023-05-15 21:22:53 +09:00
|
|
|
#!/usr/bin/env -S deno run --allow-read=. --allow-write=. --allow-run=git
|
2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2023-03-21 22:38:07 +09:00
|
|
|
|
chore: move cli/tests/ -> tests/ (#22369)
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.
2024-02-10 13:22:13 -07:00
|
|
|
/** This copies the test files according to the config file `tests/node_compat/config.jsonc` */
|
2023-03-21 22:38:07 +09:00
|
|
|
|
2024-02-07 16:21:32 -07:00
|
|
|
import { walk } from "@test_util/std/fs/walk.ts";
|
|
|
|
import { sep } from "@test_util/std/path/mod.ts";
|
|
|
|
import { ensureFile } from "@test_util/std/fs/ensure_file.ts";
|
|
|
|
import { writeAll } from "@test_util/std/streams/write_all.ts";
|
|
|
|
import { withoutAll } from "@test_util/std/collections/without_all.ts";
|
|
|
|
import { relative } from "@test_util/std/path/posix.ts";
|
2023-03-21 22:38:07 +09:00
|
|
|
|
chore: move cli/tests/ -> tests/ (#22369)
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.
2024-02-10 13:22:13 -07:00
|
|
|
import { config, ignoreList } from "../../tests/node_compat/common.ts";
|
2023-03-21 22:38:07 +09:00
|
|
|
|
|
|
|
const encoder = new TextEncoder();
|
|
|
|
|
|
|
|
const NODE_VERSION = config.nodeVersion;
|
|
|
|
|
|
|
|
const NODE_IGNORED_TEST_DIRS = [
|
|
|
|
"addons",
|
|
|
|
"async-hooks",
|
|
|
|
"cctest",
|
|
|
|
"common",
|
|
|
|
"doctool",
|
|
|
|
"embedding",
|
|
|
|
"fixtures",
|
|
|
|
"fuzzers",
|
|
|
|
"js-native-api",
|
|
|
|
"node-api",
|
|
|
|
"overlapped-checker",
|
|
|
|
"report",
|
|
|
|
"testpy",
|
|
|
|
"tick-processor",
|
|
|
|
"tools",
|
|
|
|
"v8-updates",
|
|
|
|
"wasi",
|
|
|
|
"wpt",
|
|
|
|
];
|
|
|
|
|
2023-05-15 21:22:53 +09:00
|
|
|
const VENDORED_NODE_TEST = new URL("node/test/", import.meta.url);
|
2023-03-21 22:38:07 +09:00
|
|
|
const NODE_COMPAT_TEST_DEST_URL = new URL(
|
chore: move cli/tests/ -> tests/ (#22369)
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.
2024-02-10 13:22:13 -07:00
|
|
|
"../../tests/node_compat/test/",
|
2023-03-21 22:38:07 +09:00
|
|
|
import.meta.url,
|
|
|
|
);
|
|
|
|
|
|
|
|
async function getNodeTests(): Promise<string[]> {
|
|
|
|
const paths: string[] = [];
|
2023-05-15 21:22:53 +09:00
|
|
|
const rootPath = VENDORED_NODE_TEST.href.slice(7);
|
2023-03-21 22:38:07 +09:00
|
|
|
for await (
|
2023-05-15 21:22:53 +09:00
|
|
|
const item of walk(VENDORED_NODE_TEST, { exts: [".js"] })
|
2023-03-21 22:38:07 +09:00
|
|
|
) {
|
|
|
|
const path = relative(rootPath, item.path);
|
|
|
|
if (NODE_IGNORED_TEST_DIRS.every((dir) => !path.startsWith(dir))) {
|
|
|
|
paths.push(path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return paths.sort();
|
|
|
|
}
|
|
|
|
|
|
|
|
function getDenoTests() {
|
|
|
|
return Object.entries(config.tests)
|
|
|
|
.filter(([testDir]) => !NODE_IGNORED_TEST_DIRS.includes(testDir))
|
|
|
|
.flatMap(([testDir, tests]) => tests.map((test) => testDir + "/" + test));
|
|
|
|
}
|
|
|
|
|
|
|
|
async function updateToDo() {
|
2024-01-22 10:20:59 +11:00
|
|
|
using file = await Deno.open(new URL("./TODO.md", import.meta.url), {
|
2023-03-21 22:38:07 +09:00
|
|
|
write: true,
|
|
|
|
create: true,
|
|
|
|
truncate: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const missingTests = withoutAll(await getNodeTests(), await getDenoTests());
|
|
|
|
|
|
|
|
await file.write(encoder.encode(`<!-- deno-fmt-ignore-file -->
|
|
|
|
# Remaining Node Tests
|
|
|
|
|
chore: move cli/tests/ -> tests/ (#22369)
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.
2024-02-10 13:22:13 -07:00
|
|
|
NOTE: This file should not be manually edited. Please edit \`tests/node_compat/config.json\` and run \`deno task setup\` in \`tools/node_compat\` dir instead.
|
2023-03-21 22:38:07 +09:00
|
|
|
|
|
|
|
Total: ${missingTests.length}
|
|
|
|
|
|
|
|
`));
|
|
|
|
for (const test of missingTests) {
|
|
|
|
await file.write(
|
|
|
|
encoder.encode(
|
|
|
|
`- [${test}](https://github.com/nodejs/node/tree/v${NODE_VERSION}/test/${test})\n`,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function clearTests() {
|
|
|
|
console.log("Cleaning up previous tests");
|
|
|
|
for await (
|
|
|
|
const file of walk(NODE_COMPAT_TEST_DEST_URL, {
|
|
|
|
includeDirs: false,
|
|
|
|
skip: ignoreList,
|
|
|
|
})
|
|
|
|
) {
|
|
|
|
await Deno.remove(file.path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Checks if file has entry in config.json */
|
|
|
|
function hasEntry(file: string, suite: string) {
|
|
|
|
return Array.isArray(config.tests[suite]) &&
|
|
|
|
config.tests[suite].includes(file);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function copyTests() {
|
|
|
|
console.log("Copying test files...");
|
|
|
|
|
2023-05-15 21:22:53 +09:00
|
|
|
for await (const entry of walk(VENDORED_NODE_TEST, { skip: ignoreList })) {
|
2023-03-21 22:38:07 +09:00
|
|
|
const fragments = entry.path.split(sep);
|
|
|
|
// suite is the directory name after test/. For example, if the file is
|
2023-06-26 15:10:27 +02:00
|
|
|
// "node_compat/node/test/fixtures/policy/main.mjs"
|
2023-03-21 22:38:07 +09:00
|
|
|
// then suite is "fixtures/policy"
|
2023-05-15 21:22:53 +09:00
|
|
|
const suite = fragments.slice(fragments.indexOf("node_compat") + 3, -1)
|
2023-03-21 22:38:07 +09:00
|
|
|
.join("/");
|
|
|
|
if (!hasEntry(entry.name, suite)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
const dest = new URL(`${suite}/${entry.name}`, NODE_COMPAT_TEST_DEST_URL);
|
|
|
|
await ensureFile(dest);
|
|
|
|
const destFile = await Deno.open(dest, {
|
|
|
|
create: true,
|
|
|
|
truncate: true,
|
|
|
|
write: true,
|
|
|
|
});
|
|
|
|
const srcFile = await Deno.open(
|
2023-05-15 21:22:53 +09:00
|
|
|
new URL(`${suite}/${entry.name}`, VENDORED_NODE_TEST),
|
2023-03-21 22:38:07 +09:00
|
|
|
);
|
2023-05-15 21:22:53 +09:00
|
|
|
// Add header to js files
|
2023-04-18 00:36:49 +09:00
|
|
|
if (dest.pathname.endsWith("js")) {
|
|
|
|
await writeAll(
|
|
|
|
destFile,
|
|
|
|
encoder.encode(`// deno-fmt-ignore-file
|
2023-03-21 22:38:07 +09:00
|
|
|
// deno-lint-ignore-file
|
|
|
|
|
|
|
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
|
|
|
// Taken from Node ${NODE_VERSION}
|
2023-06-02 07:05:32 +01:00
|
|
|
// This file is automatically generated by \`tools/node_compat/setup.ts\`. Do not modify this file manually.
|
2023-03-21 22:38:07 +09:00
|
|
|
|
|
|
|
`),
|
2023-04-18 00:36:49 +09:00
|
|
|
);
|
|
|
|
}
|
2023-03-21 22:38:07 +09:00
|
|
|
await srcFile.readable.pipeTo(destFile.writable);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// main
|
|
|
|
|
|
|
|
await clearTests();
|
|
|
|
await copyTests();
|
|
|
|
await updateToDo();
|
2023-05-15 21:22:53 +09:00
|
|
|
|
|
|
|
if (Deno.args[0] === "--check") {
|
|
|
|
const cmd = new Deno.Command("git", { args: ["status", "-s"] });
|
|
|
|
const { stdout } = await cmd.output();
|
|
|
|
|
|
|
|
if (stdout.length > 0) {
|
|
|
|
console.log("The following files have been changed:");
|
|
|
|
console.log(new TextDecoder().decode(stdout));
|
|
|
|
Deno.exit(1);
|
|
|
|
}
|
|
|
|
}
|