Skip to content
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

module: prefer async/await in https imports #41950

Closed

Conversation

benjamingr
Copy link
Member

@benjamingr benjamingr commented Feb 12, 2022

cc @bmeck @nodejs/modules

This PR refactors the fetch_module fetchWithRedirects function to use the new modern facilities for streams:

  • compose instead of pipe for simplified and "more easily correct" error handling on the body stream cc @ronag .
  • async/await over new Promise.
  • toArray() on the response body instead of manually.

Note this can probably be further simplified by always caching the promise (and never the value) and by moving the "memoize" functionality to a helper).

Fixes: #41950

@nodejs-github-bot
Copy link
Collaborator

Review requested:

  • @nodejs/modules

@nodejs-github-bot nodejs-github-bot added esm Issues and PRs related to the ECMAScript Modules implementation. needs-ci PRs that need a full CI run. labels Feb 12, 2022
@GeoffreyBooth GeoffreyBooth requested a review from bmeck February 13, 2022 00:03
@GeoffreyBooth
Copy link
Member

cc @JakobJingleheimer

Copy link
Member

@GeoffreyBooth GeoffreyBooth left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some minor style notes, I haven’t reviewed in depth.

lib/internal/modules/esm/fetch_module.js Outdated Show resolved Hide resolved
lib/internal/modules/esm/fetch_module.js Outdated Show resolved Hide resolved
lib/internal/modules/esm/fetch_module.js Outdated Show resolved Hide resolved
@benjamingr
Copy link
Member Author

@GeoffreyBooth fixed + added http 404 handling

@bmeck
Copy link
Member

bmeck commented Feb 13, 2022

Note this can probably be further simplified by always caching the promise (and never the value) and by moving the "memoize" functionality to a helper).

This is actually a bit complicated since import.meta.url needs the value synchronously for the response location after all redirects so it actually relies on storing the value for now.

@benjamingr
Copy link
Member Author

This is actually a bit complicated since import.meta.url needs the value synchronously for the response location after all redirects so it actually relies on storing the value for now.

Ah, mind if I add a comment to the code explaining that around the cacheForGET code?

@bmeck
Copy link
Member

bmeck commented Feb 13, 2022

Ah, mind if I add a comment to the code explaining that around the cacheForGET code?

I'm all for comments

@benjamingr
Copy link
Member Author

Added both comments.

Copy link
Member

@JakobJingleheimer JakobJingleheimer left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oow, fancy. Much cleaner than .on(…) 🙌

@@ -32,6 +30,9 @@ const path = require('path');
/**
* Only for GET requests, other requests would need new Map
* HTTP cache semantics keep diff caches
*
* It caches either the promise or the cahce entry since import.meta.url needs
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
* It caches either the promise or the cahce entry since import.meta.url needs
* It caches either the promise or the cache entry since import.meta.url needs

lib/internal/modules/esm/fetch_module.js Outdated Show resolved Hide resolved
@benjamingr
Copy link
Member Author

@bmeck @nodejs/modules this could use some reviews :)

Copy link
Contributor

@guybedford guybedford left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we get a 404 test though to land?

@benjamingr benjamingr force-pushed the use-async-await-in-fetch-module branch 2 times, most recently from 67713f1 to ace0812 Compare February 16, 2022 18:05
@benjamingr benjamingr added the request-ci Add this label to start a Jenkins CI on a PR. label Feb 16, 2022
@benjamingr
Copy link
Member Author

Added test :)

@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Feb 16, 2022
@nodejs-github-bot
Copy link
Collaborator

@nodejs-github-bot
Copy link
Collaborator

@benjamingr benjamingr added the commit-queue Add this label to land a pull request using GitHub Actions. label Feb 19, 2022
@benjamingr benjamingr added request-ci Add this label to start a Jenkins CI on a PR. and removed commit-queue-failed An error occurred while landing this pull request using GitHub Actions. labels Feb 23, 2022
@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Feb 23, 2022
@nodejs-github-bot
Copy link
Collaborator

@benjamingr benjamingr force-pushed the use-async-await-in-fetch-module branch from b3ef5cb to b575c6d Compare February 23, 2022 11:18
@benjamingr benjamingr added the request-ci Add this label to start a Jenkins CI on a PR. label Feb 23, 2022
@github-actions github-actions bot removed the request-ci Add this label to start a Jenkins CI on a PR. label Feb 23, 2022
@nodejs-github-bot
Copy link
Collaborator

@nodejs-github-bot
Copy link
Collaborator

@nodejs-github-bot
Copy link
Collaborator

@benjamingr benjamingr added the commit-queue Add this label to land a pull request using GitHub Actions. label Feb 23, 2022
@nodejs-github-bot nodejs-github-bot added commit-queue-failed An error occurred while landing this pull request using GitHub Actions. and removed commit-queue Add this label to land a pull request using GitHub Actions. labels Feb 23, 2022
@nodejs-github-bot
Copy link
Collaborator

Commit Queue failed
- Loading data for nodejs/node/pull/41950
✔  Done loading data for nodejs/node/pull/41950
----------------------------------- PR info ------------------------------------
Title      module: prefer async/await in https imports (#41950)
Author     Benjamin Gruenbaum  (@benjamingr)
Branch     benjamingr:use-async-await-in-fetch-module -> nodejs:master
Labels     esm, needs-ci
Commits    1
 - module: prefer async/await in https imports
Committers 1
 - Benjamin Gruenbaum 
PR-URL: https://github.com/nodejs/node/pull/41950
Fixes: https://github.com/nodejs/node/issues/41950
Reviewed-By: Guy Bedford 
Reviewed-By: James M Snell 
------------------------------ Generated metadata ------------------------------
PR-URL: https://github.com/nodejs/node/pull/41950
Fixes: https://github.com/nodejs/node/issues/41950
Reviewed-By: Guy Bedford 
Reviewed-By: James M Snell 
--------------------------------------------------------------------------------
   ⚠  Commits were pushed since the last review:
   ⚠  - module: prefer async/await in https imports
   ℹ  This PR was created on Sat, 12 Feb 2022 18:50:10 GMT
   ✔  Approvals: 2
   ✔  - Guy Bedford (@guybedford): https://github.com/nodejs/node/pull/41950#pullrequestreview-884778590
   ✔  - James M Snell (@jasnell) (TSC): https://github.com/nodejs/node/pull/41950#pullrequestreview-889949951
   ✔  Last GitHub CI successful
   ℹ  Last Full PR CI on 2022-02-23T18:10:07Z: https://ci.nodejs.org/job/node-test-pull-request/42748/
- Querying data for job/node-test-pull-request/42748/
   ✔  Last Jenkins CI successful
--------------------------------------------------------------------------------
   ✔  Aborted `git node land` session in /home/runner/work/node/node/.ncu
https://github.com/nodejs/node/actions/runs/1889467631

@benjamingr
Copy link
Member Author

Landed in 7efef74 🎉

@benjamingr benjamingr closed this Feb 23, 2022
benjamingr added a commit that referenced this pull request Feb 23, 2022
PR-URL: #41950
Fixes: #41950
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: James M Snell <[email protected]>
sxa pushed a commit to sxa/node that referenced this pull request Mar 7, 2022
PR-URL: nodejs#41950
Fixes: nodejs#41950
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: James M Snell <[email protected]>
@sxa sxa mentioned this pull request Mar 8, 2022
xtx1130 pushed a commit to xtx1130/node that referenced this pull request Apr 25, 2022
PR-URL: nodejs#41950
Fixes: nodejs#41950
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: James M Snell <[email protected]>
@juanarbol
Copy link
Member

This is failing in the v16.x branch; let me work in a backport for this:

/node --inspect --experimental-network-imports --dns-result-order=ipv4first test/es-module/test-http-imports.mjs                                                                                 
Debugger listening on ws://127.0.0.1:9229/924045ba-ef66-4869-84bf-085849cbf26b                                                                                                                      
For help, see: https://nodejs.org/en/docs/inspector                                                                                                                                                 
node:internal/errors:465                                                                                                                                                                            
    ErrorCaptureStackTrace(err);                                                                                                                                                                    
    ^                                                                                                                                                                                               
                                                                                                                                                                                                    
TypeError [ERR_INVALID_ARG_TYPE]: The "list" argument must be an instance of Array. Received an instance of Buffer                                                                                  
    at concat (node:buffer:537:3)                                                                                                                                                                   
    at node:internal/modules/esm/fetch_module:165:24                                                                                                                                                
    at processTicksAndRejections (node:internal/process/task_queues:96:5)                                                                                                                           
    at async node:internal/modules/esm/fetch_module:171:7                                                                                                                                           
    at async defaultLoad (node:internal/modules/esm/load:21:14)                                                                                                                                         at async ESMLoader.load (node:internal/modules/esm/loader:407:20)                                                                                                                               
    at async ESMLoader.moduleProvider (node:internal/modules/esm/loader:326:11)                                                                                                                     
    at async link (node:internal/modules/esm/module_job:70:21) {                                                                                                                                    
  code: 'ERR_INVALID_ARG_TYPE'                                                                                                                                                                      
}                                

Looks like the toArray() method is returning the Buffer not the array, see: https://github.com/nodejs/node/pull/41553/files#diff-00d8d040a3fe90e3052af39cb55dc9bcac70539d5d17791449cbfe7e3b55fb90R1903-R1904

targos pushed a commit that referenced this pull request Jul 19, 2022
PR-URL: #41950
Fixes: #41950
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: James M Snell <[email protected]>
targos pushed a commit that referenced this pull request Jul 31, 2022
PR-URL: #41950
Fixes: #41950
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: James M Snell <[email protected]>
guangwong pushed a commit to noslate-project/node that referenced this pull request Oct 10, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
commit-queue-failed An error occurred while landing this pull request using GitHub Actions. esm Issues and PRs related to the ECMAScript Modules implementation. needs-ci PRs that need a full CI run.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants