From d0d9bc3d1e0bcef1094af58c15cf997507777067 Mon Sep 17 00:00:00 2001 From: Tim Fish Date: Thu, 12 Dec 2024 16:17:47 +0100 Subject: [PATCH] feat: Support absolute paths for `include` (#168) --- hook.js | 4 ++-- test/fixtures/import-absolute-after.mjs | 10 ++++++++++ test/fixtures/import-absolute.mjs | 18 ++++++++++++++++++ ...8.19-include-message-port-absolute-path.mjs | 14 ++++++++++++++ 4 files changed, 44 insertions(+), 2 deletions(-) create mode 100644 test/fixtures/import-absolute-after.mjs create mode 100644 test/fixtures/import-absolute.mjs create mode 100644 test/register/v18.19-include-message-port-absolute-path.mjs diff --git a/hook.js b/hook.js index 1629e72..2e1ee88 100644 --- a/hook.js +++ b/hook.js @@ -2,7 +2,7 @@ // // This product includes software developed at Datadog (https://www.datadoghq.com/). Copyright 2021 Datadog, Inc. -const { URL } = require('url') +const { URL, fileURLToPath } = require('url') const { inspect } = require('util') const { builtinModules } = require('module') const specifiers = new Map() @@ -341,7 +341,7 @@ function createHook (meta) { return each.test(result.url) } - return each === specifier || each === result.url + return each === specifier || each === result.url || (result.url.startsWith('file:') && each === fileURLToPath(result.url)) } if (includeModules && !includeModules.some(match)) { diff --git a/test/fixtures/import-absolute-after.mjs b/test/fixtures/import-absolute-after.mjs new file mode 100644 index 0000000..caef978 --- /dev/null +++ b/test/fixtures/import-absolute-after.mjs @@ -0,0 +1,10 @@ +import { strictEqual } from 'assert' +import * as foo from './foo.mjs' +import { dirname, join } from 'path' +import { fileURLToPath } from 'url' + +const fooPath = join(dirname(fileURLToPath(import.meta.url)), 'foo.mjs') + +strictEqual(typeof foo.foo, 'function') +strictEqual(global.hooked.length, 1) +strictEqual(global.hooked[0], fooPath) diff --git a/test/fixtures/import-absolute.mjs b/test/fixtures/import-absolute.mjs new file mode 100644 index 0000000..2f23932 --- /dev/null +++ b/test/fixtures/import-absolute.mjs @@ -0,0 +1,18 @@ +import { register } from 'module' +import { Hook, createAddHookMessageChannel } from '../../index.js' +import { dirname, join } from 'path' +import { fileURLToPath } from 'url' + +const fooPath = join(dirname(fileURLToPath(import.meta.url)), 'foo.mjs') + +const { registerOptions, waitForAllMessagesAcknowledged } = createAddHookMessageChannel() + +register('../../hook.mjs', import.meta.url, registerOptions) + +global.hooked = [] + +Hook([fooPath], (_, name) => { + global.hooked.push(name) +}) + +await waitForAllMessagesAcknowledged() diff --git a/test/register/v18.19-include-message-port-absolute-path.mjs b/test/register/v18.19-include-message-port-absolute-path.mjs new file mode 100644 index 0000000..210d483 --- /dev/null +++ b/test/register/v18.19-include-message-port-absolute-path.mjs @@ -0,0 +1,14 @@ +import { spawnSync } from 'child_process' + +const out = spawnSync(process.execPath, + ['--import', './test/fixtures/import-absolute.mjs', './test/fixtures/import-absolute-after.mjs'], + { stdio: 'inherit', env: {} } +) + +if (out.error) { + console.error(out.error) +} +if (out.status !== 0) { + console.error(`Expected exit code 0, got ${out.status}`) +} +process.exit(out.status)