From 58b7ea211da3e0d5a9ab5ee94d7f7a773be763a0 Mon Sep 17 00:00:00 2001 From: Antoine du Hamel Date: Wed, 11 Sep 2024 23:48:02 +0200 Subject: [PATCH] esm: throw `ERR_REQUIRE_ESM` instead of `ERR_INTERNAL_ASSERTION` PR-URL: https://github.com/nodejs/node/pull/54868 Fixes: https://github.com/nodejs/node/issues/54773 Reviewed-By: James M Snell Reviewed-By: Luigi Pinca --- lib/internal/modules/esm/loader.js | 5 +++-- test/es-module/test-typescript.mjs | 12 ++++++++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/lib/internal/modules/esm/loader.js b/lib/internal/modules/esm/loader.js index 45f685c71ad028..0ac3ed855a6278 100644 --- a/lib/internal/modules/esm/loader.js +++ b/lib/internal/modules/esm/loader.js @@ -326,8 +326,6 @@ class ModuleLoader { * @returns {ModuleJobBase} */ getModuleJobForRequire(specifier, parentURL, importAttributes) { - assert(getOptionValue('--experimental-require-module')); - const parsed = URLParse(specifier); if (parsed != null) { const protocol = parsed.protocol; @@ -346,6 +344,9 @@ class ModuleLoader { } const { url, format } = resolveResult; + if (!getOptionValue('--experimental-require-module')) { + throw new ERR_REQUIRE_ESM(url, true); + } const resolvedImportAttributes = resolveResult.importAttributes ?? importAttributes; let job = this.loadCache.get(url, resolvedImportAttributes.type); if (job !== undefined) { diff --git a/test/es-module/test-typescript.mjs b/test/es-module/test-typescript.mjs index 0a713a36e42ace..f8b79261495638 100644 --- a/test/es-module/test-typescript.mjs +++ b/test/es-module/test-typescript.mjs @@ -28,6 +28,18 @@ test('execute a TypeScript file with imports', async () => { strictEqual(result.code, 0); }); +test('execute a TypeScript file with imports', async () => { + const result = await spawnPromisified(process.execPath, [ + '--no-warnings', + '--eval', + `assert.throws(() => require(${JSON.stringify(fixtures.path('typescript/ts/test-import-fs.ts'))}), {code: 'ERR_REQUIRE_ESM'})`, + ]); + + strictEqual(result.stderr, ''); + strictEqual(result.stdout, ''); + strictEqual(result.code, 0); +}); + test('execute a TypeScript file with imports with default-type module', async () => { const result = await spawnPromisified(process.execPath, [ '--experimental-strip-types',