diff --git a/lib/internal/main/worker_thread.js b/lib/internal/main/worker_thread.js index 30f7a5f79e50fd..cfd1d1b6f18e29 100644 --- a/lib/internal/main/worker_thread.js +++ b/lib/internal/main/worker_thread.js @@ -53,6 +53,7 @@ let debug = require('internal/util/debuglog').debuglog('worker', (fn) => { }); const assert = require('internal/assert'); +const { getOptionValue } = require('internal/options'); const { exitCodes: { kGenericUserError } } = internalBinding('errors'); prepareWorkerThreadExecution(); @@ -153,7 +154,7 @@ port.on('message', (message) => { break; } - case 'classic': { + case 'classic': if (getOptionValue('--input-type') !== 'module') { const { evalScript } = require('internal/process/execution'); const name = '[worker eval]'; // This is necessary for CJS module compilation. @@ -169,6 +170,7 @@ port.on('message', (message) => { break; } + // eslint-disable-next-line no-fallthrough case 'module': { const { evalModuleEntryPoint } = require('internal/process/execution'); PromisePrototypeThen(evalModuleEntryPoint(filename), undefined, (e) => { diff --git a/test/parallel/test-worker-cli-options.js b/test/parallel/test-worker-cli-options.js index ae59dcb6e62d48..0c243d251e97bc 100644 --- a/test/parallel/test-worker-cli-options.js +++ b/test/parallel/test-worker-cli-options.js @@ -1,6 +1,6 @@ // Flags: --expose-internals --expose-gc 'use strict'; -require('../common'); +const common = require('../common'); const { Worker } = require('worker_threads'); const assert = require('assert'); @@ -29,3 +29,11 @@ new Worker(CODE, { eval: true, env: process.env, execArgv: ['--expose-internals' assert.throws(() => { new Worker(CODE, { eval: true, execArgv: ['--expose-gc'] }); }, /ERR_WORKER_INVALID_EXEC_ARGV/); + +// Test ESM eval +new Worker('export {}', { eval: true, execArgv: ['--input-type=module'] }); +new Worker('export {}', { eval: true, execArgv: ['--input-type=commonjs'] }) + .once('error', common.expectsError({ name: 'SyntaxError' })); +new Worker('export {}', { eval: true, execArgv: ['--experimental-detect-module'] }); +new Worker('export {}', { eval: true, execArgv: ['--no-experimental-detect-module'] }) + .once('error', common.expectsError({ name: 'SyntaxError' }));