2023-03-26 18:22:09 +09:00
|
|
|
# Tools for Node.js compatibility work
|
|
|
|
|
|
|
|
We run
|
|
|
|
[native Node.js test cases](https://github.com/nodejs/node/tree/main/test)
|
|
|
|
against our Node.js compatibility feature.
|
|
|
|
|
|
|
|
This directory includes the tools for downloading, setting up, and updating the
|
|
|
|
Node.js compat testing in Deno repository.
|
|
|
|
|
2024-04-03 09:24:55 +11:00
|
|
|
- `//tests/node_compat/runner/setup.ts`
|
2023-03-26 18:22:09 +09:00
|
|
|
- This script sets up the Node.js compat tests.
|
2024-04-03 09:24:55 +11:00
|
|
|
- `//tests/node_compat/runner/versions/`
|
2023-03-26 18:22:09 +09:00
|
|
|
- Node.js source tarballs and extracted test cases are stored here.
|
2024-03-05 22:49:21 +02:00
|
|
|
- `//tests/node_compat/config.jsonc`
|
2023-03-26 18:22:09 +09:00
|
|
|
- This json file stores the settings about which Node.js compat test to run
|
|
|
|
with Deno.
|
2024-03-05 22:49:21 +02:00
|
|
|
- `//tests/node_compat/test`
|
2023-03-26 18:22:09 +09:00
|
|
|
- The actual test cases are stored here.
|
|
|
|
|
|
|
|
## Steps to add new test cases from Node.js test cases
|
|
|
|
|
2024-03-05 22:49:21 +02:00
|
|
|
1. Update `tests` property of `//tests/node_compat/config.jsonc`. For example,
|
|
|
|
if you want to add `test/parallel/test-foo.js` from Node.js test cases, then
|
|
|
|
add `test-foo.js` entry in `tests.parallel` array property in `config.jsonc`
|
2024-04-03 09:24:55 +11:00
|
|
|
1. Run `deno task setup` in `tests/node_compat/runner` dir.
|
2023-03-26 18:22:09 +09:00
|
|
|
|
|
|
|
The above command copies the updated items from Node.js tarball to the Deno
|
|
|
|
source tree.
|
|
|
|
|
|
|
|
Ideally Deno should pass the Node.js compat tests without modification, but if
|
2023-06-26 15:10:27 +02:00
|
|
|
you need to modify it, then add that item in `ignore` property of
|
2023-05-26 04:00:29 +01:00
|
|
|
`config.jsonc`. Then `setup.ts` doesn't overwrite the modified Node.js test
|
|
|
|
cases anymore.
|
2023-03-26 18:22:09 +09:00
|
|
|
|
|
|
|
If the test needs to be ignored in particular platform, then add them in
|
2023-05-26 04:00:29 +01:00
|
|
|
`${platform}Ignore` property of `config.jsonc`
|
2023-03-26 18:22:09 +09:00
|
|
|
|
|
|
|
## Run Node.js test cases
|
|
|
|
|
|
|
|
Node.js compat tests are run as part of `cargo test` command. If you want to run
|
|
|
|
only the Node.js compat test cases you can use the command
|
2023-06-01 09:31:06 +01:00
|
|
|
`cargo test node_compat`. If you want to run specific tests you can use the
|
2024-04-03 09:24:55 +11:00
|
|
|
command `deno task test` (in `tests/node_compat/runner` dir). For example, if
|
|
|
|
you want to run all test files which contains `buffer` in filename you can use
|
|
|
|
the command:
|
2023-06-01 09:31:06 +01:00
|
|
|
|
|
|
|
```shellsession
|
2024-04-03 09:24:55 +11:00
|
|
|
/path/to/deno/tests/node_compat/runner
|
2023-06-01 09:31:06 +01:00
|
|
|
$ deno task test buffer
|
|
|
|
```
|