From e54cd4e35cee9811b933423494b997f098fbe103 Mon Sep 17 00:00:00 2001 From: Geoffrey Booth Date: Tue, 14 Feb 2023 21:12:17 -0800 Subject: [PATCH] code review notes --- test/es-module/test-esm-loader-event-loop.mjs | 12 ++---- .../test-esm-loader-spawn-promisified.mjs | 42 +++++++++++++------ ...aders-this-value-inside-hook-functions.mjs | 4 -- 3 files changed, 33 insertions(+), 25 deletions(-) delete mode 100644 test/es-module/test-loaders-this-value-inside-hook-functions.mjs diff --git a/test/es-module/test-esm-loader-event-loop.mjs b/test/es-module/test-esm-loader-event-loop.mjs index c6a071fe25feed..d94e55148d85d7 100644 --- a/test/es-module/test-esm-loader-event-loop.mjs +++ b/test/es-module/test-esm-loader-event-loop.mjs @@ -1,16 +1,12 @@ // Flags: --experimental-loader ./test/fixtures/es-module-loaders/hooks-custom.mjs 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..8f20eba9b925c9 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.