mirror of
https://github.com/nodejs/node.git
synced 2024-11-30 15:30:56 +01:00
f91b4e2bf0
PR-URL: https://github.com/nodejs/node/pull/49633 Reviewed-By: Jacob Smith <jacob@frende.me> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Guy Bedford <guybedford@gmail.com>
52 lines
1.8 KiB
JavaScript
52 lines
1.8 KiB
JavaScript
import { spawnPromisified } from '../common/index.mjs';
|
|
import { fileURL } from '../common/fixtures.mjs';
|
|
import { doesNotMatch, match, strictEqual } from 'node:assert';
|
|
import { execPath } from 'node:process';
|
|
import { describe, it } from 'node:test';
|
|
|
|
|
|
describe('ESM: warn for obsolete hooks provided', { concurrency: true }, () => {
|
|
it('should not print warnings when no experimental features are enabled or used', async () => {
|
|
const { code, signal, stderr } = await spawnPromisified(execPath, [
|
|
'--input-type=module',
|
|
'--eval',
|
|
`import ${JSON.stringify(fileURL('es-module-loaders', 'module-named-exports.mjs'))}`,
|
|
]);
|
|
|
|
doesNotMatch(
|
|
stderr,
|
|
/ExperimentalWarning/,
|
|
new Error('No experimental warning(s) should be emitted when no experimental feature is enabled')
|
|
);
|
|
strictEqual(code, 0);
|
|
strictEqual(signal, null);
|
|
});
|
|
|
|
describe('experimental warnings for enabled experimental feature', () => {
|
|
for (
|
|
const [experiment, ...args] of [
|
|
[
|
|
/`--experimental-loader` may be removed in the future/,
|
|
'--experimental-loader',
|
|
fileURL('es-module-loaders', 'hooks-custom.mjs'),
|
|
],
|
|
[/Network Imports/, '--experimental-network-imports'],
|
|
]
|
|
) {
|
|
it(`should print for ${experiment.toString().replaceAll('/', '')}`, async () => {
|
|
const { code, signal, stderr } = await spawnPromisified(execPath, [
|
|
...args,
|
|
'--input-type=module',
|
|
'--eval',
|
|
`import ${JSON.stringify(fileURL('es-module-loaders', 'module-named-exports.mjs'))}`,
|
|
]);
|
|
|
|
match(stderr, /ExperimentalWarning/);
|
|
match(stderr, experiment);
|
|
strictEqual(code, 0);
|
|
strictEqual(signal, null);
|
|
});
|
|
}
|
|
});
|
|
});
|