-
Notifications
You must be signed in to change notification settings - Fork 3.3k
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
small optimization #7176
small optimization #7176
Conversation
@@ -1,4 +1,4 @@ | |||
const { cleanUrl } = require('npm-registry-fetch') | |||
const cleanUrl = require('npm-registry-fetch/lib/clean-url') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We tend not to do this as it unnecessarily couples to the layout of the code, and not its exports. module.exports
is the module, as far a our semver conventions are concerned. This allows us to completely refactor or rewrite a module and not make it a breaking change, as long as the exports are the same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The layout of internal files is already part of the api and subject to semver, unless the exports field is used to encapsulate them.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
so that the future refactor does not introduce destructive changes
I suggest adding an export field to the package.json of this module, will this solve this problem?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Something like that would have to be a larger decision/discussion than just one repo, it falls under how we build all of our software. Currently we define a main
entry .e.g. https://github.com/npm/npm-registry-fetch/blob/e58e8bc6c5b25d53a764f58190fc3a5c764a2e78/package.json#L5, and rely on module.exports
to define the api.
exports
is an alternative to main
, not a replacement. We are not moving to exports
right now so my original, single-line suggestion is all we really want to do right now.
The line as it is now was done very intentionally, and adding that function to module.exports
was the way in which it was exported.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To clarify, you suggest leaving require('npm-registry-fetch')
even though it adds ~15% to the runtime
If the only problem is that you are just starting to migrate to declaring exports
in package.json
, then I could first send a PR to npm-registry-fetch
so that I can painlessly import only cleanUrl
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes leave it. A pr to npm-registry-fetch
would be rejected as we would want to centrally manage that entry in package.json from @npmcli/template-oss
and enforce it on ALL our packages.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
38 milliseconds (15% of 256) for npm run
is not something we need to hyper optimize. This is not a hot path like reification.
❯ hyperfine -w 5 -r 20 'npm run echo' 'node bin/npm-cli.js run echo'
Benchmark 1: npm run echo
Time (mean ± σ): 253.7 ms ± 4.0 ms [User: 252.9 ms, System: 34.0 ms]
Range (min … max): 250.2 ms … 268.7 ms 20 runs
Benchmark 2: node bin/npm-cli.js run echo
Time (mean ± σ): 208.4 ms ± 5.0 ms [User: 184.4 ms, System: 24.1 ms]
Range (min … max): 205.9 ms … 229.5 ms 20 runs
Warning: Statistical outliers were detected. Consider re-running this benchmark on a quiet system without any interferences from other programs. It might help to use the '--warmup' or '--prepare' options.
Summary
node bin/npm-cli.js run echo ran
1.22 ± 0.04 times faster than npm run echo |
This has been addressed by #7334 |
What
small optimization withprocess.title
require
Describe the request in detail. What it does and why it's being changed.
it takes extra time when running any code (this reduced execution time by ~15%)
changing process.title is a synchronous operation that blocks the thread, it is better to reduce the number of calls of this command (allowed to reduce the execution time by 5%)moved the optional
require
, imports only what is used,./utils/replace-info.js
is quite a heavy dependency, moving it to the function where it is called allowed to reduce the time by 5%Result: