From 92c05c21da2390b847f911f755e1f87bfcce68a1 Mon Sep 17 00:00:00 2001 From: Moshe Atlow Date: Wed, 3 May 2023 10:53:57 +0300 Subject: [PATCH 1/2] module: block requiring `test/reporters` without scheme --- lib/internal/bootstrap/realm.js | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/internal/bootstrap/realm.js b/lib/internal/bootstrap/realm.js index c8cdaeff7d369b..ecf2f7caed742a 100644 --- a/lib/internal/bootstrap/realm.js +++ b/lib/internal/bootstrap/realm.js @@ -132,6 +132,7 @@ const legacyWrapperList = new SafeSet([ // Modules that can only be imported via the node: scheme. const schemelessBlockList = new SafeSet([ 'test', + 'test/reporters', ]); // Modules that will only be enabled at run time. const experimentalModuleList = new SafeSet(); From dcb9657944c4c35d219930c84a791971d6512199 Mon Sep 17 00:00:00 2001 From: Moshe Atlow Date: Wed, 3 May 2023 18:01:27 +0300 Subject: [PATCH 2/2] fixup! module: block requiring `test/reporters` without scheme --- test/parallel/test-runner-import-no-scheme.js | 51 ++++++++++++------- 1 file changed, 33 insertions(+), 18 deletions(-) diff --git a/test/parallel/test-runner-import-no-scheme.js b/test/parallel/test-runner-import-no-scheme.js index 45dd83d0251988..85953af77bf9a5 100644 --- a/test/parallel/test-runner-import-no-scheme.js +++ b/test/parallel/test-runner-import-no-scheme.js @@ -7,45 +7,60 @@ const fs = require('fs'); const path = require('path'); const { createRequire } = require('module'); -assert.throws( - () => require('test'), - common.expectsError({ code: 'MODULE_NOT_FOUND' }), -); - -(async () => { - await assert.rejects( - async () => import('test'), - common.expectsError({ code: 'ERR_MODULE_NOT_FOUND' }), +for (const name in ['test', 'test/reporters']) { + assert.throws( + () => require(name), + common.expectsError({ code: 'MODULE_NOT_FOUND' }), ); -})().then(common.mustCall()); -assert.throws( - () => require.resolve('test'), - common.expectsError({ code: 'MODULE_NOT_FOUND' }), -); + (async () => { + await assert.rejects( + async () => import(name), + common.expectsError({ code: 'ERR_MODULE_NOT_FOUND' }), + ); + })().then(common.mustCall()); + + assert.throws( + () => require.resolve(name), + common.expectsError({ code: 'MODULE_NOT_FOUND' }), + ); +} // Verify that files in node_modules can be resolved. tmpdir.refresh(); const packageRoot = path.join(tmpdir.path, 'node_modules', 'test'); +const reportersDir = path.join(tmpdir.path, 'node_modules', 'test', 'reporters'); const indexFile = path.join(packageRoot, 'index.js'); +const reportersIndexFile = path.join(reportersDir, 'index.js'); -fs.mkdirSync(packageRoot, { recursive: true }); +fs.mkdirSync(reportersDir, { recursive: true }); fs.writeFileSync(indexFile, 'module.exports = { marker: 1 };'); +fs.writeFileSync(reportersIndexFile, 'module.exports = { marker: 1 };'); -function test(argv) { +function test(argv, expectedToFail = false) { const child = spawnSync(process.execPath, argv, { cwd: tmpdir.path }); - assert.strictEqual(child.status, 0); - assert.strictEqual(child.stdout.toString().trim(), '{ marker: 1 }'); + if (expectedToFail) { + assert.strictEqual(child.status, 1); + assert.strictEqual(child.stdout.toString().trim(), ''); + } else { + assert.strictEqual(child.status, 0); + assert.strictEqual(child.stdout.toString().trim(), '{ marker: 1 }'); + } } test(['-e', 'console.log(require("test"))']); +test(['-e', 'console.log(require("test/reporters"))']); test(['-e', 'import("test").then(m=>console.log(m.default))']); +test(['-e', 'import("test/reporters").then(m=>console.log(m.default))'], true); test(['--input-type=module', '-e', 'import test from "test";console.log(test)']); +test(['--input-type=module', '-e', 'import test from "test/reporters";console.log(test)'], true); test(['--input-type=module', '-e', 'console.log((await import("test")).default)']); +test(['--input-type=module', '-e', 'console.log((await import("test/reporters")).default)'], true); { const dummyFile = path.join(tmpdir.path, 'file.js'); const require = createRequire(dummyFile); assert.strictEqual(require.resolve('test'), indexFile); + assert.strictEqual(require.resolve('test/reporters'), reportersIndexFile); }