diff --git a/lib/internal/modules/esm/default_resolve.js b/lib/internal/modules/esm/default_resolve.js index 67b8db716c5b01..88377689ce4fd7 100644 --- a/lib/internal/modules/esm/default_resolve.js +++ b/lib/internal/modules/esm/default_resolve.js @@ -91,8 +91,7 @@ function resolve(specifier, parentURL) { if (isMain) format = type === TYPE_MODULE ? 'module' : 'commonjs'; else - throw new ERR_UNKNOWN_FILE_EXTENSION(fileURLToPath(url), - fileURLToPath(parentURL)); + throw new ERR_UNKNOWN_FILE_EXTENSION(fileURLToPath(url)); } return { url: `${url}`, format }; } diff --git a/test/es-module/test-esm-invalid-extension.js b/test/es-module/test-esm-invalid-extension.js new file mode 100644 index 00000000000000..9e676e57d1b90f --- /dev/null +++ b/test/es-module/test-esm-invalid-extension.js @@ -0,0 +1,13 @@ +'use strict'; +require('../common'); +const fixtures = require('../common/fixtures'); +const assert = require('assert'); +const { spawnSync } = require('child_process'); +const fixture = fixtures.path('/es-modules/import-invalid-ext.mjs'); +const child = spawnSync(process.execPath, ['--experimental-modules', fixture]); +const errMsg = 'TypeError [ERR_UNKNOWN_FILE_EXTENSION]: Unknown file extension'; + +assert.strictEqual(child.status, 1); +assert.strictEqual(child.signal, null); +assert.strictEqual(child.stdout.toString().trim(), ''); +assert(child.stderr.toString().includes(errMsg)); diff --git a/test/fixtures/es-modules/import-invalid-ext.mjs b/test/fixtures/es-modules/import-invalid-ext.mjs new file mode 100644 index 00000000000000..2de34252192a98 --- /dev/null +++ b/test/fixtures/es-modules/import-invalid-ext.mjs @@ -0,0 +1 @@ +import './simple.wat';