mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
bae14b7914
Our CI already run test files in parallel, having `node:test` spawns child processes concurrently could lead to oversubscribing the CI machine. This commit sets the `concurrency` depending on the presence of `TEST_PARALLEL` in the env, so running the test file individually still spawns child processes concurrently, and running the whole test suite does not oversubscribe the machine. PR-URL: https://github.com/nodejs/node/pull/52177 Reviewed-By: Vinícius Lourenço Claro Cardoso <contact@viniciusl.com.br> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Marco Ippolito <marcoippolito54@gmail.com>
162 lines
5.4 KiB
JavaScript
162 lines
5.4 KiB
JavaScript
import { spawnPromisified } from '../common/index.mjs';
|
|
import fixtures from '../common/fixtures.js';
|
|
import assert from 'node:assert';
|
|
import { execPath } from 'node:process';
|
|
import { describe, it } from 'node:test';
|
|
|
|
|
|
const commonArgs = [
|
|
'--input-type=module',
|
|
'--eval',
|
|
];
|
|
|
|
describe('ESM: unsettled and rejected promises', { concurrency: !process.env.TEST_PARALLEL }, () => {
|
|
it('should exit for an unsettled TLA promise via --eval with a warning', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
...commonArgs,
|
|
'await new Promise(() => {})',
|
|
]);
|
|
|
|
assert.match(stderr, /Warning: Detected unsettled top-level await at.+\[eval1\]:1/);
|
|
assert.match(stderr, /await new Promise/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 13);
|
|
});
|
|
|
|
it('should exit for an unsettled TLA promise via --eval without warning', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
...commonArgs,
|
|
'await new Promise(() => {})',
|
|
]);
|
|
|
|
assert.strictEqual(stderr, '');
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 13);
|
|
});
|
|
|
|
it('should throw for a rejected TLA promise via --eval', async () => {
|
|
// Rejected TLA promise, --eval
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
...commonArgs,
|
|
'await Promise.reject(new Error("Xyz"))',
|
|
]);
|
|
|
|
assert.match(stderr, /Error: Xyz/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 1);
|
|
});
|
|
|
|
it('should exit for an unsettled TLA promise and respect explicit exit code via --eval', async () => {
|
|
// Rejected TLA promise, --eval
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
...commonArgs,
|
|
'process.exitCode = 42;await new Promise(() => {})',
|
|
]);
|
|
|
|
assert.strictEqual(stderr, '');
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 42);
|
|
});
|
|
|
|
it('should throw for a rejected TLA promise and ignore explicit exit code via --eval', async () => {
|
|
// Rejected TLA promise, --eval
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
...commonArgs,
|
|
'process.exitCode = 42;await Promise.reject(new Error("Xyz"))',
|
|
]);
|
|
|
|
assert.match(stderr, /Error: Xyz/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 1);
|
|
});
|
|
|
|
it('should exit for an unsettled TLA promise with warning', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
fixtures.path('es-modules/tla/unresolved.mjs'),
|
|
]);
|
|
|
|
assert.match(stderr, /Warning: Detected unsettled top-level await at.+unresolved\.mjs:1/);
|
|
assert.match(stderr, /await new Promise/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 13);
|
|
});
|
|
|
|
it('should exit for an unsettled TLA promise without warning', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
fixtures.path('es-modules/tla/unresolved.mjs'),
|
|
]);
|
|
|
|
assert.strictEqual(stderr, '');
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 13);
|
|
});
|
|
|
|
it('should throw for a rejected TLA promise via stdin', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
fixtures.path('es-modules/tla/rejected.mjs'),
|
|
]);
|
|
|
|
assert.match(stderr, /Error: Xyz/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 1);
|
|
});
|
|
|
|
it('should exit for an unsettled TLA promise and respect explicit exit code via stdin', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
fixtures.path('es-modules/tla/unresolved-withexitcode.mjs'),
|
|
]);
|
|
|
|
assert.strictEqual(stderr, '');
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 42);
|
|
});
|
|
|
|
it('should throw for a rejected TLA promise and ignore explicit exit code via stdin', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
fixtures.path('es-modules/tla/rejected-withexitcode.mjs'),
|
|
]);
|
|
|
|
assert.match(stderr, /Error: Xyz/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 1);
|
|
});
|
|
|
|
it('should exit successfully when calling `process.exit()` in `.mjs` file', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
fixtures.path('es-modules/tla/process-exit.mjs'),
|
|
]);
|
|
|
|
assert.strictEqual(stderr, '');
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 0);
|
|
});
|
|
|
|
it('should be unaffected by `process.exit()` in worker thread', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
fixtures.path('es-modules/tla/unresolved-with-worker-process-exit.mjs'),
|
|
]);
|
|
|
|
assert.match(stderr, /Warning: Detected unsettled top-level await at.+with-worker-process-exit\.mjs:5/);
|
|
assert.match(stderr, /await new Promise/);
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 13);
|
|
});
|
|
|
|
it('should be unaffected by `process.exit()` in worker thread without warning', async () => {
|
|
const { code, stderr, stdout } = await spawnPromisified(execPath, [
|
|
'--no-warnings',
|
|
fixtures.path('es-modules/tla/unresolved-with-worker-process-exit.mjs'),
|
|
]);
|
|
|
|
assert.strictEqual(stderr, '');
|
|
assert.strictEqual(stdout, '');
|
|
assert.strictEqual(code, 13);
|
|
});
|
|
});
|