-
Notifications
You must be signed in to change notification settings - Fork 13k
Open
Labels
Fix AvailableA PR has been opened for this issueA PR has been opened for this issueNeeds InvestigationThis issue needs a team member to investigate its status.This issue needs a team member to investigate its status.
Milestone
Description
π Search Terms
dynamic import, import attribute, resolveJsonModule,
π Version & Regression Information
- This is the behavior in every version I tried, and I reviewed the FAQ for entries about TS 5.7's new checks around importing JSON
β― Playground Link
https://github.com/kirkwaiblinger/repro-TS-dynamic-json-import-validation
π» Code
// module: node16/nodenext, resolveJsonModule
// .cts or .mts, it doesn't matter.
async function main() {
const somethingDynamic = await import('./someThing.json');
console.log('dynamically imported JSON:', somethingDynamic);
}
main();
export {}
π Actual behavior
No error, even though this is a runtime error in nodejs.
π Expected behavior
Error because dynamic import('./someThing.json')
requires import attribute.
Additional information about the issue
Unlike the static import case, this is the case for both commonjs and esm outputs, since import()
is available in commonjs modules in node and has the same semantics there as the ESM import (and therefore TS doesn't transform the import()
statement to a Promise.resolve(require())
).
Metadata
Metadata
Assignees
Labels
Fix AvailableA PR has been opened for this issueA PR has been opened for this issueNeeds InvestigationThis issue needs a team member to investigate its status.This issue needs a team member to investigate its status.