diff options
author | Matt Mastracci <matthew@mastracci.com> | 2024-02-10 13:22:13 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-02-10 20:22:13 +0000 |
commit | f5e46c9bf2f50d66a953fa133161fc829cecff06 (patch) | |
tree | 8faf2f5831c1c7b11d842cd9908d141082c869a5 /tests/node_compat/common.ts | |
parent | d2477f780630a812bfd65e3987b70c0d309385bb (diff) |
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.
Diffstat (limited to 'tests/node_compat/common.ts')
-rw-r--r-- | tests/node_compat/common.ts | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/tests/node_compat/common.ts b/tests/node_compat/common.ts new file mode 100644 index 000000000..e079c6aaf --- /dev/null +++ b/tests/node_compat/common.ts @@ -0,0 +1,64 @@ +// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license. +import { partition } from "@test_util/std/collections/partition.ts"; +import { join } from "@test_util/std/path/mod.ts"; +import * as JSONC from "@test_util/std/jsonc/mod.ts"; +/** + * The test suite matches the folders inside the `test` folder inside the + * node repo + * + * Each test suite contains a list of files (which can be paths + * or a regex to match) that will be pulled from the node repo + */ +type TestSuites = Record<string, string[]>; + +interface Config { + nodeVersion: string; + /** Ignored files won't regenerated by the update script */ + ignore: TestSuites; + /** + * The files that will be run by the test suite + * + * The files to be generated with the update script must be listed here as well, + * but they won't be regenerated if they are listed in the `ignore` configuration + */ + tests: TestSuites; + windowsIgnore: TestSuites; + darwinIgnore: TestSuites; +} + +export const config: Config = JSONC.parse( + await Deno.readTextFile(new URL("./config.jsonc", import.meta.url)), +) as unknown as Config; + +export const ignoreList = Object.entries(config.ignore).reduce( + (total: RegExp[], [suite, paths]) => { + paths.forEach((path) => total.push(new RegExp(join(suite, path)))); + return total; + }, + [/package\.json/], +); + +export function getPathsFromTestSuites(suites: TestSuites): string[] { + const testPaths: string[] = []; + for (const [dir, paths] of Object.entries(suites)) { + if ( + ["parallel", "internet", "pummel", "sequential", "pseudo-tty"].includes( + dir, + ) + ) { + for (const path of paths) { + testPaths.push(join(dir, path)); + } + } + } + return testPaths; +} + +const PARALLEL_PATTERN = /^parallel[\/\\]/; + +export function partitionParallelTestPaths( + testPaths: string[], +): { parallel: string[]; sequential: string[] } { + const partitions = partition(testPaths, (p) => !!p.match(PARALLEL_PATTERN)); + return { parallel: partitions[0], sequential: partitions[1] }; +} |