A function to get notified when a stream is no longer readable, writable
or has experienced an error or a premature close event.
const { finished } = require('stream');
constrs = fs.createReadStream('archive.tar');
finished(rs, (err) => { if (err) { console.error('Stream failed.', err); } else { console.log('Stream is done reading.'); } });
rs.resume(); // Drain the stream.
Especially useful in error handling scenarios where a stream is destroyed
prematurely (like an aborted HTTP request), and will not emit 'end' or 'finish'.
The finished API provides promise version:
const { finished } = require('stream/promises');
constrs = fs.createReadStream('archive.tar');
asyncfunctionrun() { awaitfinished(rs); console.log('Stream is done reading.'); }
run().catch(console.error); rs.resume(); // Drain the stream.
stream.finished() leaves dangling event listeners (in particular'error', 'end', 'finish' and 'close') after callback has been
invoked. The reason for this is so that unexpected 'error' events (due to
incorrect stream implementations) do not cause unexpected crashes.
If this is unwanted behavior then the returned cleanup function needs to be
invoked in the callback:
A function to get notified when a stream is no longer readable, writable or has experienced an error or a premature close event.
Especially useful in error handling scenarios where a stream is destroyed prematurely (like an aborted HTTP request), and will not emit
'end'
or'finish'
.The
finished
API provides promise version:stream.finished()
leaves dangling event listeners (in particular'error'
,'end'
,'finish'
and'close'
) aftercallback
has been invoked. The reason for this is so that unexpected'error'
events (due to incorrect stream implementations) do not cause unexpected crashes. If this is unwanted behavior then the returned cleanup function needs to be invoked in the callback: