summaryrefslogtreecommitdiff
path: root/tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js
diff options
context:
space:
mode:
authorsnek <snek@deno.com>2024-10-28 18:16:43 +0100
committerGitHub <noreply@github.com>2024-10-28 18:16:43 +0100
commit4e38fbd0a3e0ca139314e503494a8d4795007d8a (patch)
treedd67b5eee1348e03a688c4ba42b60f42774420b5 /tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js
parentf61af864df4d7a2513f738ddf2d5fddf79c878af (diff)
fix: report exceptions from nextTick (#26579)
Fixes: https://github.com/denoland/deno/issues/24713 Fixes: https://github.com/denoland/deno/issues/25855
Diffstat (limited to 'tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js')
-rw-r--r--tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js b/tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js
new file mode 100644
index 000000000..f511d2500
--- /dev/null
+++ b/tests/node_compat/test/parallel/test-child-process-ipc-next-tick.js
@@ -0,0 +1,46 @@
+// 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 `tests/node_compat/runner/setup.ts`. Do not modify this file manually.
+
+'use strict';
+const common = require('../common');
+const assert = require('assert');
+const cp = require('child_process');
+const NUM_MESSAGES = 10;
+const values = [];
+
+for (let i = 0; i < NUM_MESSAGES; ++i) {
+ values[i] = i;
+}
+
+if (process.argv[2] === 'child') {
+ const received = values.map(() => { return false; });
+
+ process.on('uncaughtException', common.mustCall((err) => {
+ received[err] = true;
+ const done = received.every((element) => { return element === true; });
+
+ if (done)
+ process.disconnect();
+ }, NUM_MESSAGES));
+
+ process.on('message', (msg) => {
+ // If messages are handled synchronously, throwing should break the IPC
+ // message processing.
+ throw msg;
+ });
+
+ process.send('ready');
+} else {
+ const child = cp.fork(__filename, ['child']);
+
+ child.on('message', common.mustCall((msg) => {
+ assert.strictEqual(msg, 'ready');
+ values.forEach((value) => {
+ child.send(value);
+ });
+ }));
+}