summaryrefslogtreecommitdiff
path: root/cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js
diff options
context:
space:
mode:
authorYoshiya Hinosawa <stibium121@gmail.com>2023-02-21 00:35:04 +0900
committerGitHub <noreply@github.com>2023-02-20 16:35:04 +0100
commit6915a9b7a701dde0e1078867961c9a91811c1850 (patch)
treee6822f2b8400c7c7941d3cb9ace59842389b5bc9 /cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js
parenta1cd2a5915c13f6a9b8eafa3807e143a02616bc1 (diff)
test(ext/node): more node compat tests (#17827)
This PR adds the remaining ~650 Node.js compat test cases from std/node. Among these 650 cases, about 130 cases are now failing. These failing cases are prefixed with `TODO:` in `tests/node_compat/config.json`. These will be addressed in later PRs.
Diffstat (limited to 'cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js')
-rw-r--r--cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js66
1 files changed, 66 insertions, 0 deletions
diff --git a/cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js b/cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js
new file mode 100644
index 000000000..fe3e8765e
--- /dev/null
+++ b/cli/tests/node_compat/test/parallel/test-child-process-execFile-promisified-abortController.js
@@ -0,0 +1,66 @@
+// 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 "node/_tools/setup.ts". Do not modify this file manually
+
+// TODO(PolarETech): The args passed to promisified() should not need to
+// include "require.ts".
+
+'use strict';
+
+const common = require('../common');
+const assert = require('assert');
+const { promisify } = require('util');
+const execFile = require('child_process').execFile;
+const fixtures = require('../common/fixtures');
+
+const echoFixture = fixtures.path('echo.js');
+const promisified = promisify(execFile);
+const invalidArgTypeError = {
+ code: 'ERR_INVALID_ARG_TYPE',
+ name: 'TypeError'
+};
+
+{
+ // Verify that the signal option works properly
+ const ac = new AbortController();
+ const signal = ac.signal;
+ const promise = promisified(process.execPath, ['require.ts', echoFixture, 0], { signal });
+
+ ac.abort();
+
+ assert.rejects(
+ promise,
+ { name: 'AbortError' }
+ ).then(common.mustCall());
+}
+
+{
+ // Verify that the signal option works properly when already aborted
+ const signal = AbortSignal.abort();
+
+ assert.rejects(
+ promisified(process.execPath, ['require.ts', echoFixture, 0], { signal }),
+ { name: 'AbortError' }
+ ).then(common.mustCall());
+}
+
+{
+ // Verify that if something different than Abortcontroller.signal
+ // is passed, ERR_INVALID_ARG_TYPE is thrown
+ const signal = {};
+ assert.throws(() => {
+ promisified(process.execPath, ['require.ts', echoFixture, 0], { signal });
+ }, invalidArgTypeError);
+}
+
+{
+ // Verify that if something different than Abortcontroller.signal
+ // is passed, ERR_INVALID_ARG_TYPE is thrown
+ const signal = 'world!';
+ assert.throws(() => {
+ promisified(process.execPath, ['require.ts', echoFixture, 0], { signal });
+ }, invalidArgTypeError);
+}