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

Undocumented breaking change in stream.pipeline? #33050

Closed
aduh95 opened this issue Apr 24, 2020 · 22 comments
Closed

Undocumented breaking change in stream.pipeline? #33050

aduh95 opened this issue Apr 24, 2020 · 22 comments
Labels
stream Issues and PRs related to the stream subsystem.

Comments

@aduh95
Copy link
Contributor

aduh95 commented Apr 24, 2020

  • Version: 14.0.0
  • Platform: any
  • Subsystem: stream, doc

What steps will reproduce the bug?

It seems Node.js 14 introduced a breaking change in the stream.pipeline API, however the docs doesn't reference any change related to Node 14.

Refs: max-mapper/extract-zip#94

TLDR of the above issue is that sometimes the promisified version of pipeline never resolves, causing the program to hang or to exit with unfinished promises.

How often does it reproduce? Is there a required condition?

I have a limited knowledge of the Node.js Stream API, I haven't been able to isolate the bug in the issue I referenced above.

What is the expected behavior?

If there is a breaking change on Node.js 14, it should be documented, at least in the YAML metadata.

Ideally there would be a migration guide to workaround the breaking change.

What do you see instead?

Last documented change references 13.10.0.

Additional information

Probably related to #32158.

CC: @ronag

@himself65 himself65 added the stream Issues and PRs related to the stream subsystem. label Apr 25, 2020
@himself65
Copy link
Member

I think we have another undocumented semver-major change

like #32987

@ronag
Copy link
Member

ronag commented Apr 25, 2020

#32987

@himself65 how is that related to streams?

@ronag
Copy link
Member

ronag commented Apr 25, 2020

@aduh95 Do you think you could provide a full example on how to reproduce?

@himself65
Copy link
Member

@himself65 how is that related to streams?

Absolutely not, I just thought this's maybe an undocumented update issue like that one. Because the commit 1428a92 which author mentioned to only release in V14

@ronag
Copy link
Member

ronag commented Apr 25, 2020

FYI, I've moved the conversation to max-mapper/extract-zip#94 for now until I know how to reproduce the issue.

@targos
Copy link
Member

targos commented Apr 25, 2020

I had a similar issue with another zip extracting library. I can try to make a repro.

@ronag
Copy link
Member

ronag commented Apr 25, 2020

I had a similar issue with another zip extracting library. I can try to make a repro.

Thanks. I'm struggling to make it fail. So far all my tries succeed.

@ronag
Copy link
Member

ronag commented Apr 25, 2020

Ok, I managed to make it fail, pre #32967.

@aduh95 Can you confirm whether this is still a problem after #32967?

@targos
Copy link
Member

targos commented Apr 25, 2020

@ronag see https://github.com/targos/bug-zip-pipeline

Expected: node test.js should print two lines (start/finished reading zip file) and the zip file should be fully extracted at result/.

Actual:

  • Node.js 13: works
  • Node.js 14.0.0: only one file is extracted and one line is printed
  • Latest 15.0.0 nightly: only one file is extracted and one line is printed

Edit:

If pipeline is replaced with manual pipe + on('finish'), it works in all versions.

@aduh95
Copy link
Contributor Author

aduh95 commented Apr 25, 2020

@aduh95 Can you confirm whether this is still a problem after #32967?

Yes, I can confirm it is still a problem. I am also able to reproduce using @targos repo:

$ npm install
$ ../node/out/Release/node --version
v15.0.0-pre
$ ../node/out/Release/node test.js
start reading zip file
$ node13 --version
v13.13.0
$ node13 test.js 
(node:53994) ExperimentalWarning: The ESM module loader is experimental.
start reading zip file
finished reading zip file

@ronag
Copy link
Member

ronag commented Apr 25, 2020

The problem seems to be that the read stream never emits a 'close' event event though it probably should. Either need to fix the read stream or make finished even more strict in regards to when to assume it should wait for 'close'. Digging...

@ronag
Copy link
Member

ronag commented Apr 25, 2020

So the problem goes back to fd-slicer which implements its own destroy() function overriding the stream default autoDestroy behavior, thus it never emits 'close'.

https://github.com/andrewrk/node-fd-slicer/blob/master/index.js#L102

At the moment I'm a little unsure how to fix this without basically to large degree disabling the willEmitClose behavior https://github.com/nodejs/node/blob/master/lib/internal/streams/end-of-stream.js#L75.

@ronag
Copy link
Member

ronag commented Apr 25, 2020

Neither fd-slicer not yauzl seems to be maintained anymore 😞 so fixing them does not feel likely. thejoshwolfe/yauzl#115

@jasnell
Copy link
Member

jasnell commented Apr 25, 2020

/cc @mafintosh @mcollina

ronag added a commit to nxtedition/node that referenced this issue Apr 25, 2020
Try to detect non standard streams and don't wait for
'close' on these. In particular if we detected
that destroyed is true before we expect it to be then
fallback to compat behavior.

Fixes: nodejs#33050
@ronag
Copy link
Member

ronag commented Apr 25, 2020

I think this should fix it, #33058

@mcollina
Copy link
Member

@ronag could you also send a PR that list the semver-major changes to the history of pipeline/finished etc?

@ronag
Copy link
Member

ronag commented Apr 25, 2020

@ronag could you also send a PR that list the semver-major changes to the history of pipeline/finished etc?

Sure, though I don't quite understand what that means in practice? In the documentation? Where and how? i.e. what is "the history of pipeline/finished etc"?

#33065

@ronag

This comment has been minimized.

BethGriggs pushed a commit that referenced this issue Apr 27, 2020
Try to detect non standard streams and don't wait for
'close' on these. In particular if we detected
that destroyed is true before we expect it to be then
fallback to compat behavior.

Fixes: #33050

PR-URL: #33058
Reviewed-By: Matteo Collina <[email protected]>
Reviewed-By: Michaël Zasso <[email protected]>
Reviewed-By: Zeyu Yang <[email protected]>
BethGriggs pushed a commit that referenced this issue Apr 28, 2020
Try to detect non standard streams and don't wait for
'close' on these. In particular if we detected
that destroyed is true before we expect it to be then
fallback to compat behavior.

Fixes: #33050

PR-URL: #33058
Reviewed-By: Matteo Collina <[email protected]>
Reviewed-By: Michaël Zasso <[email protected]>
Reviewed-By: Zeyu Yang <[email protected]>
BethGriggs pushed a commit that referenced this issue Apr 28, 2020
Try to detect non standard streams and don't wait for
'close' on these. In particular if we detected
that destroyed is true before we expect it to be then
fallback to compat behavior.

Fixes: #33050

PR-URL: #33058
Reviewed-By: Matteo Collina <[email protected]>
Reviewed-By: Michaël Zasso <[email protected]>
Reviewed-By: Zeyu Yang <[email protected]>
@barisusakli
Copy link

Can anyone confirm if this issue is fixed? File uploads still fail with a simple app with connect-multiparty. expressjs/connect-multiparty#29

@aduh95
Copy link
Contributor Author

aduh95 commented Apr 29, 2020

I can confirm it is fixed on Node.js 14.1.0, I haven't tested the app you referenced though.

@StephenLynx
Copy link

14.3 and multi-party is still broken tbh fam

@exe-dealer
Copy link

here is my minimal bug reproduction https://github.com/exe-dealer/node-iss-33050
node v10 works fine, but node v14 is broken

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
stream Issues and PRs related to the stream subsystem.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

9 participants