Closed
Description
Hi,
I'm running into an issue with all node versions >= 10.10.
The problem is that, sometimes (I cannot pinpoint exactly under which conditions), putting streams into multipipe seems to stop the flow, so streams are piped but no data is actually flowing.
As a test, you can run the following code:
const multipipe = require('multipipe')
const { PassThrough } = require('stream')
const stringToStream = (string) => {
const myStream = new PassThrough()
myStream.end(Buffer.from(string, 'binary'))
return myStream
}
const str = 'a'.repeat(1e6)
const returnStream = new PassThrough()
let tmp = ''
returnStream
.on('data', (chunk) => {
tmp += chunk
})
.on('end', () => {
console.log(tmp.length)
})
const input = stringToStream(str)
const outputStream = multipipe(new PassThrough(), returnStream)
multipipe(input, outputStream)
// outputStream.resume()
On node < 10.10, you get a log of 1000000
, as is expected.
On node >= 10.10, you get nothing, except if you uncomment the last line.
This unexpected behaviour is easy to workaround (just add a .resume()
), but quite annoying... It seems linked to nodejs/node#22209 and nodejs/node#18994 .
Metadata
Metadata
Assignees
Labels
No labels