From 0e15269bc97a2369703b5d92757a73a931e4505f Mon Sep 17 00:00:00 2001 From: Myles Borins Date: Wed, 7 Oct 2020 15:33:34 -0400 Subject: [PATCH] doc: add missing meeting notes (#560) Closes: https://github.com/nodejs/modules/issues/532 Closes: https://github.com/nodejs/modules/issues/543 Closes: https://github.com/nodejs/modules/issues/548 Closes: https://github.com/nodejs/modules/issues/552 --- doc/meetings/2020-07-15.md | 49 ++++++++++++++++++++++ doc/meetings/2020-08-12.md | 83 ++++++++++++++++++++++++++++++++++++++ doc/meetings/2020-08-26.md | 64 +++++++++++++++++++++++++++++ doc/meetings/2020-09-09.md | 42 +++++++++++++++++++ 4 files changed, 238 insertions(+) create mode 100644 doc/meetings/2020-07-15.md create mode 100644 doc/meetings/2020-08-12.md create mode 100644 doc/meetings/2020-08-26.md create mode 100644 doc/meetings/2020-09-09.md diff --git a/doc/meetings/2020-07-15.md b/doc/meetings/2020-07-15.md new file mode 100644 index 0000000..f23fa1b --- /dev/null +++ b/doc/meetings/2020-07-15.md @@ -0,0 +1,49 @@ +# Node.js Modules Team Meeting 2020-07-15 + +## Links + +* **Recording**: http://www.youtube.com/watch?v=LOHDJGs_FNs +* **GitHub Issue**: https://github.com/nodejs/modules/issues/532 +* **Minutes Google Doc**: https://docs.google.com/document/d/1iEMdSLFXIpEwtAzogOOcGQZgS87fZDerdRVnCSldjUM/edit + +## Present + +* Myles Borins (@MylesBorins) +* Guy Bedford (@guybedford) +* Wesley Wigham (@weswigham) +* Darcy Clarke (@darcyclarke) +* Bruce MacNaughton (@bmacnaughton) +* Julian Londono (@julian-londono) +* Jordan Harband (@ljharb) + +## Agenda + +## Announcements + +*Extracted from **modules-agenda** labelled issues and pull requests from the **nodejs org** prior to the meeting. + +### nodejs/node + +* esm: Modify getFormat and getSource loader hooks [#34144](https://github.com/nodejs/node/pull/34144) + +Crux of the issue, example: an https loader having to make a request in `getFormat` to get the resource format, then again in `getSource` to get the resource +Having state throughout the 4 loader hooks may be able to solve this +Pushing a tricky GC issue to loader hooks that may not be able to rely on getSource always being called after getFormat (especially once chaining exists). +PR should delve more into edge cases and document exploration further, covering possible alternatives. +Make sure PR works with Gus’s compositional loader PR [#33812](https://github.com/nodejs/node/pull/33812) + + +* Special treatment for package.json resolution and exports? [#33460](https://github.com/nodejs/node/issues/33460) + - Refs: + - add API for "package dir" [#516](https://github.com/nodejs/modules/issues/516) + - up for debate on the placement (ex. `module`, `require`, `import.meta`) + - proposed interface/method name: `resolvePackageRoot` + - ex. usage, `.resolvePackageRoot(import.meta.url)` & `.resolvePackageRoot(process.cwd())`, `.resolvePackageRoot(__dirname)` (?) + +* module: CJS exports detection [#33416](https://github.com/nodejs/node/pull/33416) + PR has been updated to use a flag. Should we let the PR work stall at this point? - no active interest in pursuing any escalation for the block. +- Concerns raised based on heuristic not being fully accurate. +- Discussed alternatives briefly. +- Suggestion to use a loader to provide the feature to users for further feedback. +- Snapshotting of CJS modules does not support loader interception - agreement that a PR to disable snapshotting and allow CJS mutation to allow a loader would be preferable to not being able to support CJS named exports. +- Discussion to open meta issue related to group handling of these types of consensus issues. diff --git a/doc/meetings/2020-08-12.md b/doc/meetings/2020-08-12.md new file mode 100644 index 0000000..0dae583 --- /dev/null +++ b/doc/meetings/2020-08-12.md @@ -0,0 +1,83 @@ +# Node.js Modules Team Meeting 2020-08-12 + +## Links + +* **Recording**: http://www.youtube.com/watch?v=PDFFQnbFEcM +* **GitHub Issue**: https://github.com/nodejs/modules/issues/543 +* **Minutes Google Doc**: https://docs.google.com/document/d/1zjqjv8G9fDnpGG01yBS39-tRRZPQ5E8N5aset38FKKk/edit + +## Present + +* Myles Borins (@MylesBorins) +* Bradley Farias (@bmeck) +* Guy Bedford (@guybedford) +* Doron Tsur (@qballer) +* Julian Londono (@julian-londono) +* Jordan Harband (@ljharb) +* Jan Krems (@jkrems) + +## Agenda + +## Announcements + +*Extracted from **modules-agenda** labelled issues and pull requests from the **nodejs org** prior to the meeting. + +We unflagged Top-Level Await in Node.js 14.8.0. There is an open pull-request to unflag Top-Level Await in the REPL, but it needs to be reviewed on it’s own merit as it uses a completely different implementation from TLA in ESM. There is also an open discussion about support static import in the REPL, as it could share similar infrastructure to TLA. + +### nodejs/node + +* Policy conditions [#34414](https://github.com/nodejs/node/pull/34414) + + + +* Special treatment for package.json resolution and exports? [#33460](https://github.com/nodejs/node/issues/33460) + +JHB: lots of tools need access to package.json, with "exports" there is no reliable way to get it in every situation. 3 paths forward: +1. do nothing, packages must explicitly expose package.json +2. automatically/implicitly expose package.json +3. Add API to resolve a package root + +No PR yet, but it seems like 3 is a likely route (module.getPackageRoot()?). Seems sufficient to have the ecosystem to use that without relying on require/import. + +MBS: We don't have a way of loading JSON in ESM right now. It is being worked on/standardized. I could see value in some API that loads the meta-data without all the boilerplate. This is separate from when "exports" cannot resolve a thing. I recognize people are used to having the ability to load `package.json` without opting into anything. Perhaps a opt-out via setting it to "undefined" in the JSON would work. Tools that need to get what is / is not exposed package.json is the static source of what is /is not available and they have to do this. + +JKS: If we state that tools can use X to get the package.json, it would be surprising if there is a way to opt out. It would be surprising if you were allowed to opt-out. + +MBS: A lot of these tools are expecting more than just package.json at the root and are relying on our loaders to get them. It can be a slippery slope for all the assets. + +BFS: the semantics of any API are complex / the data may not exist + +JKS: concern is around publishing a popular package, which then opts-out and then breaks the npm ecosystem. + +BFS: yes, we saw this with is-promise, but the breakage was due to implicit not explicit choice to prevent access to package.json + +JKS: Making an API to get the package root is useful one way or another. The only way for a coffeescript loader to determine the type of the package is that the loader needs to replicate behavior or make a fake filename and call the hook. Such an API would allow a loader to reuse a lot of the builtin machinery to do these tasks. + +JHB: Will proceed making PR for API. + +* module: CJS exports detection [#33416](https://github.com/nodejs/node/pull/33416) + +GBD: Geoffrey did analysis/numbers based upon specific success criteria based upon name exports intent from readmes. The block on the PR landing is from Gus on criteria must be for exact output rather than the analysis. Unclear if we can get consensus on this. Suggestion to only have criteria to detect transpiled modules to get 90+% case needed. Are we still defining the criteria about what users expect / esModules check. 81% for esModule currently 90+% for readme. +MBS: Geoffreys last comment for esModule > 99% success rate for esModule compared to docs. Accuracy seems to be an acceptable level. Any small work we can do to improve this would be good. + +GBD: *lack of clarity on if it is 99% or 81% accuracy*. If it is in the readme 99% accurate. + +MBS: maybe we can ignore all modules lacking esModule. + +JKS: numbers may be biased for a high percentage rather than package author expectation. + +### nodejs/modules + +* Subpath extension patterns and wildcard expansions [#535](https://github.com/nodejs/modules/issues/535) + +MBS: maybe we should look at stuff, dynamism is concerning. Perhaps things like an extension map in the package JSON as a separate feature. + +JHB: prioritized static in loading, we should re-evaluate usability vs static. + +* import assertions RFC [#427](https://github.com/nodejs/modules/issues/427) + +* Import Maps and Node.js [#544](https://github.com/nodejs/modules/issues/544) + +* Removing `getFormat` hook [#34114](https://github.com/nodejs/node/pull/34144/#issuecomment-666716738) + +Issue for this created [here](https://github.com/nodejs/node/issues/34753) diff --git a/doc/meetings/2020-08-26.md b/doc/meetings/2020-08-26.md new file mode 100644 index 0000000..ace44a9 --- /dev/null +++ b/doc/meetings/2020-08-26.md @@ -0,0 +1,64 @@ + +# Node.js Modules Team Meeting 2020-08-26 + +## Links + +* **Recording**: http://www.youtube.com/watch?v=9PU3XLIlzw0 +* **GitHub Issue**: https://github.com/nodejs/modules/issues/548 +* **Minutes Google Doc**: https://docs.google.com/document/d/1h-lxJGyzmBAKhiweg3hesXZ1j5PLcGFEQPZJl4rpkKc/ + +## Present + +* Myles Borins (@Myles Borins) +* Christopher Hiller (@boneskull) +* Doron Tsur (@qballer) +* Wesley Wigham (@weswigham) +* Guy Bedford (@guybedford) +* Jordan Harband (@ljharb) + +## Agenda + +## Announcements + +* Discussion about proxyquire + +- Christopher: + - Module level mocking in tests is an issue with ESM + - With common.js and requires and the cache you can do this fairly easily + - There are various modules you can use such a proxyquire + - It is nice to be able to just mock a module + - ESM makes this difficult + - I’ve seen some loader implementations out there that allow you to do this sort of thing, although I haven’t been able to play with them to figure out how sufficient they are. + - One challenge, the requirement of using the loader flag at all. We don’t necessarily know if / when we are going to start mocking things. As it’s implemented right now you can only have one loader. If you want to use a loader for something like typescript you are in a tough position + - Even with chaining loaders it puts a lot of responsibility on the user / test runner to manage this such as spawning a subprocess for every test even if the loader isn’t being used. Not very ergonomic + +### nodejs/node + +* esm: Modify ESM Experimental Loader Hooks [#34753](https://github.com/nodejs/node/issues/34753) + +Skipped + +* Special treatment for package.json resolution and exports? [#33460](https://github.com/nodejs/node/issues/33460) + +Tabled for now will come back if we have time + +* module: CJS exports detection [#33416](https://github.com/nodejs/node/pull/33416) + + + +### nodejs/modules + +* Import Maps and Node.js [#544](https://github.com/nodejs/modules/issues/544) + + + +* Add Doron Tsur as observer [#542](https://github.com/nodejs/modules/pull/542) + +Done added + +* Subpath extension patterns and wildcard expansions [#535](https://github.com/nodejs/modules/issues/535) + +* import assertions RFC [#427](https://github.com/nodejs/modules/issues/427) + + + diff --git a/doc/meetings/2020-09-09.md b/doc/meetings/2020-09-09.md new file mode 100644 index 0000000..91bb8ca --- /dev/null +++ b/doc/meetings/2020-09-09.md @@ -0,0 +1,42 @@ +# Node.js Modules Team Meeting 2020-09-09 + +## Links + +* **Recording**: http://www.youtube.com/watch?v=hh76jaYtrTE +* **GitHub Issue**: https://github.com/nodejs/modules/issues/552 +* **Minutes Google Doc**: https://docs.google.com/document/d/1EgBV_oRONelVM4nLWuzWJJEyDUqmqFF5FR0OwpqCKQU/ + +## Present + +* Modules team: @nodejs/modules +* Geoffrey Booth (@GeoffreyBooth) +* Myles Borins (@MylesBorins) +* Doron Tsur (@qballer) +* Guy Bedford (@guybedford) +* Jordan Harband (@ljharb) +* Bradley Farias (@bmeck) + +## Agenda + +## Announcements + +*Extracted from **modules-agenda** labelled issues and pull requests from the **nodejs org** prior to the meeting. + +### nodejs/node + +* module: exports patterns [#34718](https://github.com/nodejs/node/pull/34718) + +- Is the complexity worth it? Maybe! + +* Special treatment for package.json resolution and exports? [#33460](https://github.com/nodejs/node/issues/33460) + +* module: CJS exports detection [#33416](https://github.com/nodejs/node/pull/33416) + +* esm: Modify ESM Experimental Loader Hooks [#34753](https://github.com/nodejs/node/issues/34753) + +### nodejs/modules + +* Enabling import meta resolve by default? [#550](https://github.com/nodejs/modules/issues/550) +* import assertions RFC [#427](https://github.com/nodejs/modules/issues/427) +* Mocking use cases [#549](https://github.com/nodejs/modules/issues/549) +* hot reload modules w/ es6 modules [#459](https://github.com/nodejs/modules/issues/459)