-
Notifications
You must be signed in to change notification settings - Fork 30.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Hooks loading commonjs
files uses import
condition for require()
#51327
Comments
Consider sending minimal repros, i.e. no GitHub repo, and without unrelated details – this issue is only related to the |
Minimal repro: "use strict";
require("node:module").register(
`data:text/javascript,import assert from 'node:assert';export ${encodeURIComponent(
function resolve(s, c, n) {
if (s === "node:target") {
assert.ok(
!c.conditions.includes("import"),
`Conditions should not include "import", actual ${JSON.stringify(
c.conditions,
)})`,
);
assert.ok(
c.conditions.includes("require"),
`Conditions should include "require", actual ${JSON.stringify(
c.conditions,
)})`,
);
}
return n(s, c);
},
)}export ${encodeURIComponent(function load(u, c, n) {
if (u === 'custom:cjs') {
return {
format: "commonjs",
source: 'console.log(require.resolve("node:target"))',
shortCircuit: true,
};
}
return n(u, c);
})}`,
);
import('custom:cjs').then(console.log, console.error); /cc @nodejs/loaders |
Thanks for validating the bug and providing a more minimal reproduction. (For context, I personally find cloning a repo and running it to be more streamlined than manually recreating an environment. Also, I included logging to a file because the loader process wasn't logging everything to stdout.) |
From the point of view of the folks who triage the issue, it's much much quicker to have a single JS snippet to read, rather than a a repo to clone. Also, not using a repo will likely force the reporter to think on how to keep the repro as minimal as possible, which is going to come in handy when someone will need to write a test for that. |
Also a repo or something else to download is more difficult to review for malware / malicious code. |
Does this also mean that require and import dependencies are both going to be cached as modules when using the Trying to track down a very baffling bug while trying to migrate from the deprecated Haven't had success boiling it down to a minimal reproduction yet. |
@EricMCornelius Not sure if this applies to your use case, but I just saw this warning in the documentation:
|
This issue is making it harder and harder to get by in a universe with the presence of both monorepos and esm modules increasing all the time. |
Version
21.5.0
Platform
macOS
Subsystem
No response
What steps will reproduce the bug?
Reproduction: https://github.com/privatenumber/bug-node-hooks-cjs-conditions
How often does it reproduce? Is there a required condition?
A Hook needs to be registered to load
commonjs
type files.What is the expected behavior? Why is that the expected behavior?
For the conditions to include
require
whenrequire(file)
is executed.What do you see instead?
The import conditions only include
import
.Here are the logs:
Additional information
No response
The text was updated successfully, but these errors were encountered: