Skip to content

Commit 60f1a5d

Browse files
authored
process: fix wrong asyncContext under unhandled-rejections=strict
Fixes: #60034 PR-URL: #60103 Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Gerhard Stöbich <[email protected]>
1 parent ffb25b8 commit 60f1a5d

File tree

2 files changed

+30
-1
lines changed

2 files changed

+30
-1
lines changed

lib/internal/process/promises.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -281,7 +281,7 @@ function strictUnhandledRejectionsMode(promise, promiseInfo, promiseAsyncId) {
281281
reason : new UnhandledPromiseRejection(reason);
282282
// This destroys the async stack, don't clear it after
283283
triggerUncaughtException(err, true /* fromPromise */);
284-
if (promiseAsyncId === undefined) {
284+
if (promiseAsyncId !== undefined) {
285285
pushAsyncContext(
286286
promise[kAsyncIdSymbol],
287287
promise[kTriggerAsyncIdSymbol],
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
// Flags: --unhandled-rejections=strict
2+
'use strict';
3+
4+
const common = require('../common');
5+
const fs = require('fs');
6+
const assert = require('assert');
7+
8+
process.on('unhandledRejection', common.mustNotCall);
9+
10+
process.on('uncaughtException', common.mustCall((err) => {
11+
assert.ok(err.message.includes('foo'));
12+
}));
13+
14+
15+
async function readFile() {
16+
return fs.promises.readFile(__filename);
17+
}
18+
19+
async function crash() {
20+
throw new Error('foo');
21+
}
22+
23+
24+
async function main() {
25+
crash();
26+
readFile();
27+
}
28+
29+
main();

0 commit comments

Comments
 (0)