-
Notifications
You must be signed in to change notification settings - Fork 30.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
stream: adjust src hwm when pipelining #40751
base: main
Are you sure you want to change the base?
Conversation
@nodejs/startup @addaleax |
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.
A doc change is needed. This also change/simplify the pipe logic and I like it.
I'm not sure I would backport it immediately to LTS, but I'm not sure it's strictly semver-major either.
@@ -1350,7 +1347,7 @@ const tsp = require('timers/promises'); | |||
}); | |||
const cb = common.mustCall((err) => { | |||
assert.strictEqual(err.name, 'AbortError'); | |||
assert.strictEqual(res, '012345'); | |||
assert.strictEqual(res, '01234'); |
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 this?
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.
There is a timing difference due to how streams are resumed with 'readable'
event.
4d68da2
to
3d0d042
Compare
@nodejs/streams |
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.
lgtm
What happens if the source is already piped to another destination via |
Combining pipe and read is not a good idea... so no |
It will work but the consumption will be driven by pipeline as the @ronag could you add a test for this case? |
If my understanding is correct, then consumption will be driven by the fastest destination, not the slowest, potentially messing up backpressure handling, right? |
No, not really. The same happens if you mix async iterators and Unfortuunately this is the only way |
I don't really see what a test here contributes? It uses an existing api. |
Fwiw, I marked this semver-major because it’s a big breaking change to stop using
The latter sounds a lot safer to me. |
IMO if we merge this we are moving towards some from of deprecation of pipe. If we don’t merge this we’re in this inconsistent state where sometimes we use pipe and sometimes not and the situation is quite unpredictable for our users. I think we have to choose which api we recommend and stick with it in core at least. readable is simpler @mcollina wdyt? |
This needs a rebase. |
This needs a rebase, if we want to still merge it. |
No description provided.