-
Notifications
You must be signed in to change notification settings - Fork 30.1k
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
fs.createWriteStream does not fire close event #21122
Comments
I can confirm that behaviour although I don't know if it's correct or not. Different versions have different outputs. versions I used:
I've also tested it the easier way of "copying via stream" and it works as expected, both close events are emitted. const fs = require('fs')
const {resolve} = require('path')
const source = resolve(__dirname, 'index.js')
const target = resolve(__dirname, 'copy.js')
const reader = fs.createReadStream(source)
const writer = fs.createWriteStream(target);
reader.on('close', () => {
console.log('reader closed');
});
writer.on('close', () => {
console.log('writer closed');
});
reader.pipe(writer);
// prints:
// reader closed
// writer closed |
Strange. There don't seem to be any changes made in particular: ryzokuken@flying-dutchman ~/Code/nodejs/node [17:58:13]
> $ glog master..v10.0.0 | grep "fs:" [±master ✓▴]
* 65e62e5665 fs: return stats to JS in sync methods
* 5b705cddcc fs: add 'close' event to FSWatcher
* e3579a007f fs: handle long files reading in fs.promises
* d7b162cfa0 fs: complete error message for validate function @nodejs/fs any idea what's going on here? |
@ryzokuken This looks more like a stream issue rather than fs issue? |
@joyeecheung it does to me as well, but the
Therefore, I thought it'd be a filesystem bug. Will try "inspect"-ing this tomorrow, if I can. |
This is not a bug. This behavior was changed in #18994. @spurreiter I'm not really understading why are you deferring piping in #21122 (comment). Could you please articulate your use? Side note, this should work (note that we are listening for the // index.js
const fs = require('fs')
const {resolve} = require('path')
function copy (source, target, cb) {
const read = fs.createReadStream(source)
const write = fs.createWriteStream(target, {flags: 'w'})
function copyit () {
console.log('copyit')
write.on('error', function (err) {
console.log('onerror')
cb(err)
})
write.on('close', function () {
console.log('onclose')
cb(null)
})
read.pipe(write)
}
read.once('readable', copyit)
read.on('end', copyit)
}
const source = resolve(__dirname, 'index.js')
const target = resolve(__dirname, 'copy.js')
copy(source, target, (err) => {
console.log('end', err)
}) cc @oyyd |
I came across this issue on trying to upgrade to node 10. The code snippet is extracted and simplified from a npm package which refuses to work with node 10 but worked well until then. |
I've also run into this issue. Is it expected? Our motivation is to use the stream with a Node.js const stream = fs.createWriteStream('out.log', { flags: 'a' });
const logger = new Console(stream);
// Doesn't seem to fire?
stream.on('close', () => console.log('CLOSED');
logger.log('foo');
// This might be done by an external app for example
fs.unlinkSync('out.log');
logger.log('bar'); |
Unlinking a file removes its name from the parent directory, but doesn't remove the file. any open references to it remain open. You will need to periodically close and reopen the file. I wouldn't recommend building this yourself, use winston, pino, log4j or bunyan. |
The following code illustrates the observed issue:
On node>=10.0 only the
readable
event firesOn node@9.11.1 the output is
The text was updated successfully, but these errors were encountered: