diff --git a/test/es-module/test-esm-loader-event-loop.mjs b/test/es-module/test-esm-loader-event-loop.mjs index c6a071fe25feed..037e20286dadf4 100644 --- a/test/es-module/test-esm-loader-event-loop.mjs +++ b/test/es-module/test-esm-loader-event-loop.mjs @@ -2,15 +2,12 @@ import { mustCall } from '../common/index.mjs'; import assert from 'assert'; -const done = mustCall(() => { assert.ok(true); }); +const done = mustCall(); // Test that the process doesn't exit because of a caught exception thrown as part of dynamic import(). -await import('nonexistent/file.mjs').catch(() => {}); -await import('nonexistent/file.mjs').catch(() => {}); -await import('nonexistent/file.mjs').catch(() => {}); -await import('nonexistent/file.mjs').catch(() => {}); -await import('nonexistent/file.mjs').catch(() => {}); -await import('nonexistent/file.mjs').catch(() => {}); +for (let i = 0; i < 10; i++) { + await import('nonexistent/file.mjs').catch(() => {}); +} done(); diff --git a/test/es-module/test-esm-loader-spawn-promisified.mjs b/test/es-module/test-esm-loader-spawn-promisified.mjs index c5953128cc6607..805088c424f749 100644 --- a/test/es-module/test-esm-loader-spawn-promisified.mjs +++ b/test/es-module/test-esm-loader-spawn-promisified.mjs @@ -12,7 +12,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'nonexistent/file.mjs\'', + `import "nonexistent/file.mjs"`, ]); assert.strictEqual(code, 1); @@ -44,7 +44,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'esmHook/badReturnVal.mjs\'', + 'import "esmHook/badReturnVal.mjs"', ]); assert.strictEqual(code, 1); @@ -60,7 +60,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'esmHook/format.false\'', + 'import "esmHook/format.false"', ]); assert.strictEqual(code, 1); @@ -75,7 +75,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'esmHook/format.true\'', + 'import "esmHook/format.true"', ]); assert.strictEqual(code, 1); @@ -91,7 +91,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'esmHook/badReturnFormatVal.mjs\'', + 'import "esmHook/badReturnFormatVal.mjs"', ]); assert.strictEqual(code, 1); @@ -107,7 +107,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'esmHook/unsupportedReturnFormatVal.mjs\'', + 'import "esmHook/unsupportedReturnFormatVal.mjs"', ]); assert.strictEqual(code, 1); @@ -123,7 +123,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { fixtures.fileURL('/es-module-loaders/hooks-custom.mjs'), '--input-type=module', '--eval', - 'import \'esmHook/badReturnSourceVal.mjs\'', + 'import "esmHook/badReturnSourceVal.mjs"', ]); assert.strictEqual(code, 1); @@ -140,7 +140,7 @@ describe('Loader hooks throwing errors', { concurrency: true }, () => { '--input-type=module', '--eval', `import assert from 'node:assert'; - Promise.allSettled([ + await Promise.allSettled([ import('nonexistent/file.mjs'), import('${fixtures.fileURL('/es-modules/file.unknown')}'), import('esmHook/badReturnVal.mjs'), @@ -170,7 +170,7 @@ describe('Loader hooks parsing modules', { concurrency: true }, () => { '--input-type=module', '--eval', `import assert from 'node:assert'; - import('${fixtures.fileURL('/es-module-loaders/js-as-esm.js')}') + await import('${fixtures.fileURL('/es-module-loaders/js-as-esm.js')}') .then((parsedModule) => { assert.strictEqual(typeof parsedModule, 'object'); assert.strictEqual(parsedModule.namedExport, 'named-export'); @@ -191,7 +191,7 @@ describe('Loader hooks parsing modules', { concurrency: true }, () => { '--input-type=module', '--eval', `import assert from 'node:assert'; - import('${fixtures.fileURL('/es-modules/file.ext')}') + await import('${fixtures.fileURL('/es-modules/file.ext')}') .then((parsedModule) => { assert.strictEqual(typeof parsedModule, 'object'); const { default: defaultExport } = parsedModule; @@ -215,7 +215,7 @@ describe('Loader hooks parsing modules', { concurrency: true }, () => { '--input-type=module', '--eval', `import assert from 'node:assert'; - import('esmHook/preknownFormat.pre') + await import('esmHook/preknownFormat.pre') .then((parsedModule) => { assert.strictEqual(typeof parsedModule, 'object'); assert.strictEqual(parsedModule.default, 'hello world'); @@ -236,7 +236,7 @@ describe('Loader hooks parsing modules', { concurrency: true }, () => { '--input-type=module', '--eval', `import assert from 'node:assert'; - import('esmHook/virtual.mjs') + await import('esmHook/virtual.mjs') .then((parsedModule) => { assert.strictEqual(typeof parsedModule, 'object'); assert.strictEqual(typeof parsedModule.default, 'undefined'); @@ -258,7 +258,7 @@ describe('Loader hooks parsing modules', { concurrency: true }, () => { '--input-type=module', '--eval', `import assert from 'node:assert'; - import('${fixtures.fileURL('/es-modules/stateful.mjs')}') + await import('${fixtures.fileURL('/es-modules/stateful.mjs')}') .then(({ default: count }) => { assert.strictEqual(count(), 1); });`, @@ -269,4 +269,20 @@ describe('Loader hooks parsing modules', { concurrency: true }, () => { assert.strictEqual(stdout, ''); assert.strictEqual(stderr, ''); }); + + it('ensures that user loaders are not bound to the internal loader', async () => { + const { code, signal, stdout, stderr } = await spawnPromisified(execPath, [ + '--no-warnings', + '--experimental-loader', + fixtures.fileURL('/es-module-loaders/loader-this-value-inside-hook-functions.mjs'), + '--input-type=module', + '--eval', + `;`, // Actual test is inside the loader module. + ]); + + assert.strictEqual(code, 0); + assert.strictEqual(signal, null); + assert.strictEqual(stdout, ''); + assert.strictEqual(stderr, ''); + }); }); diff --git a/test/es-module/test-loaders-this-value-inside-hook-functions.mjs b/test/es-module/test-loaders-this-value-inside-hook-functions.mjs deleted file mode 100644 index b74b7d9e1e4c30..00000000000000 --- a/test/es-module/test-loaders-this-value-inside-hook-functions.mjs +++ /dev/null @@ -1,4 +0,0 @@ -// Flags: --experimental-loader ./test/fixtures/es-module-loaders/loader-this-value-inside-hook-functions.mjs -import '../common/index.mjs'; - -// Actual test is inside the loader module.