Skip to content

Commit

Permalink
test: add test for using --print with promises
Browse files Browse the repository at this point in the history
PR-URL: #52137
Reviewed-By: Vinícius Lourenço Claro Cardoso <[email protected]>
Reviewed-By: Debadree Chatterjee <[email protected]>
  • Loading branch information
aduh95 authored Mar 19, 2024
1 parent a21b15a commit be75821
Showing 1 changed file with 93 additions and 0 deletions.
93 changes: 93 additions & 0 deletions test/parallel/test-cli-print-promise.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
import { spawnPromisified } from '../common/index.mjs';
import assert from 'node:assert';
import { execPath } from 'node:process';
import { describe, it } from 'node:test';


describe('--print with a promise', { concurrency: true }, () => {
it('should handle directly-fulfilled promises', async () => {
const result = await spawnPromisified(execPath, [
'--print',
'Promise.resolve(42)',
]);

assert.deepStrictEqual(result, {
code: 0,
signal: null,
stderr: '',
stdout: 'Promise { 42 }\n',
});
});

it('should handle promises fulfilled after one tick', async () => {
const result = await spawnPromisified(execPath, [
'--print',
'Promise.resolve().then(()=>42)',
]);

assert.deepStrictEqual(result, {
code: 0,
signal: null,
stderr: '',
stdout: 'Promise { <pending> }\n',
});
});

it('should handle promise that never settles', async () => {
const result = await spawnPromisified(execPath, [
'--print',
'new Promise(()=>{})',
]);

assert.deepStrictEqual(result, {
code: 0,
signal: null,
stderr: '',
stdout: 'Promise { <pending> }\n',
});
});

it('should output something if process exits before promise settles', async () => {
const result = await spawnPromisified(execPath, [
'--print',
'setTimeout(process.exit,100, 0);timers.promises.setTimeout(200)',
]);

assert.deepStrictEqual(result, {
code: 0,
signal: null,
stderr: '',
stdout: 'Promise { <pending> }\n',
});
});

it('should handle rejected promises', async () => {
const result = await spawnPromisified(execPath, [
'--unhandled-rejections=none',
'--print',
'Promise.reject(1)',
]);

assert.deepStrictEqual(result, {
code: 0,
signal: null,
stderr: '',
stdout: 'Promise { <rejected> 1 }\n',
});
});

it('should handle promises that reject after one tick', async () => {
const result = await spawnPromisified(execPath, [
'--unhandled-rejections=none',
'--print',
'Promise.resolve().then(()=>Promise.reject(1))',
]);

assert.deepStrictEqual(result, {
code: 0,
signal: null,
stderr: '',
stdout: 'Promise { <pending> }\n',
});
});
});

0 comments on commit be75821

Please sign in to comment.