-
Notifications
You must be signed in to change notification settings - Fork 30.2k
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
[v10.x] fs: stop lazy loading stream constructors #21776
Conversation
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.
Do we need to add a test to make sure these public members of fs
are mockable (i.e. if you assign fs.member
to something else then assert.strictEqual(fs.member, mockedMember
)? It should be less useful for other modules but members of fs are mocked by users all the time in tests.
@@ -1793,43 +1778,12 @@ module.exports = fs = { | |||
writeSync, | |||
Stats, | |||
|
|||
get ReadStream() { |
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.
An alternative fix is adding setters here to allow users to override the lazy-loaded variables so we can still avoid loading the internal/fs/streams
module when requiring fs
.
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.
That's how it's implemented now. It doesn't work with jest-mock because accessors are ignored.
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.
Ah right, I see that there are setters...so this looks more like a bug of Jest?
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, maybe. But this was still kind of a sever major change and I'm not sure it's worth to do it.
Should we just wait until Jest fixes the bug instead of working around it ourselves? Looks like Jest just need to consider properties with setters as properties that can be overridden instead of bypassing every property with a getter in the descriptor? |
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.
Putting a red cross because it does not look like it has to be us fixing the regression, since we already provide setters (also because GitHub does not allow you to dismiss approvals..). This can be dismissed if it's shown that it has to be us fixing this.
function lazyFs() { | ||
if (fs === undefined) | ||
fs = require('fs'); | ||
return fs; |
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.
Why not to just return require('fs')
since require
already has a cache?
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 require
cache is slightly more expensive so we generally use this pattern through core to keep it at cheap as possible. It's likely unnecessary in most cases, but it's a consistent pattern.
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.
Okay, cool. Thank you!
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.
@jasnell we might want to benchmark the influence of that again. It would actually be so clean if we'd just use require directly.
I'm fine with fixing this in Jest (although I won't have time for it anytime soon, leaving for vacation), but it has over 1.3 million every week, and people are generally slow to update. It also broke in a minor, not a major (and the original PR was originally marked as major before passing CITGM). That said, nobody has complained to us about it not working, only noticed since our own tests broke 🙂 |
@joyeecheung I personally would say it was a unintentionally breaking change. It was the reason why I did not move that part out when I was working on improving lazy loading in Node core. So I am +1 on merging this at least on 10. |
I'm good with this change in v10 but keeping the current behavior in master and 11. |
Specifically, what I'd like to see is this PR rebased against |
Updated to target |
@joyeecheung are you fine with this landing on v10.x only? |
Landed in 484140e |
Fixes: #21489 PR-URL: #21776 Reviewed-By: Joyee Cheung <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
Fixes: #21489
/cc @nodejs/fs @SimenB
Checklist
make -j4 test
(UNIX), orvcbuild test
(Windows) passes