From 90360351b452a909f2d0d391a6565b94719e046d Mon Sep 17 00:00:00 2001 From: Chakrit Wichian Date: Wed, 21 Aug 2013 14:47:28 +0700 Subject: [PATCH 1/3] Fix #97 unref() the rotation timeout in RotatingFileStream. The rotation `setTimeout` from `RotatingFileStream` will prevent the process from exiting. This fix simply `unref()` the timeout immediately after it is set. --- lib/bunyan.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/lib/bunyan.js b/lib/bunyan.js index 6eaf539e..b43e7a65 100644 --- a/lib/bunyan.js +++ b/lib/bunyan.js @@ -990,6 +990,9 @@ RotatingFileStream.prototype._setupNextRot = function () { this.timeout = setTimeout( function () { self.rotate(); }, this.rotAt - Date.now()); + if (typeof this.timeout.unref === 'function') { + this.timeout.unref(); + } } RotatingFileStream.prototype._nextRotTime = function _nextRotTime(first) { From 6f2cc6be2d10a0b831ce6a721602b782f920f3ee Mon Sep 17 00:00:00 2001 From: Glenn Murray Date: Tue, 4 Mar 2014 15:33:44 +1100 Subject: [PATCH 2/3] Graceful termination failing test for #97 and #73 Will fail if any timers or callbacks remain registered when instantiating a logger with a rotating file. --- test/process-exit.js | 11 +++++++++++ test/process-exit.test.js | 21 +++++++++++++++++++++ 2 files changed, 32 insertions(+) create mode 100644 test/process-exit.js create mode 100644 test/process-exit.test.js diff --git a/test/process-exit.js b/test/process-exit.js new file mode 100644 index 00000000..5e547c90 --- /dev/null +++ b/test/process-exit.js @@ -0,0 +1,11 @@ +var bunyan = require('../lib/bunyan'); +var log = bunyan.createLogger({ + name: 'default', + streams: [{ + type: 'rotating-file', + path: __dirname + '/log.test.rot.log', + period: '1d', + count: 7 + }] +}); +console.log('done'); \ No newline at end of file diff --git a/test/process-exit.test.js b/test/process-exit.test.js new file mode 100644 index 00000000..954cf468 --- /dev/null +++ b/test/process-exit.test.js @@ -0,0 +1,21 @@ +'use strict'; +/* + * Test that bunyan process will terminate + */ + +var exec = require('child_process').exec; + +// node-tap API +if (require.cache[__dirname + '/tap4nodeunit.js']) + delete require.cache[__dirname + '/tap4nodeunit.js']; +var tap4nodeunit = require('./tap4nodeunit.js'); +var test = tap4nodeunit.test; + +test('log with rotating file stream will terminate gracefully', function (t) { + exec('node ' +__dirname + '/process-exit.js', {timeout: 1000}, function(err, stdout, stderr) { + t.ifError(err); + t.equal(stdout, 'done\n'); + t.equal(stderr, ''); + t.end(); + }); +}); \ No newline at end of file From 52d1abb8c9ceace72324f4343310f081c4b6f103 Mon Sep 17 00:00:00 2001 From: Glenn Murray Date: Tue, 4 Mar 2014 15:47:45 +1100 Subject: [PATCH 3/3] Changelog for 'unref' bugfix #97 --- CHANGES.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGES.md b/CHANGES.md index c184a355..1e355f4b 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -8,7 +8,7 @@ Known issues: ## bunyan 0.22.2 (not yet released) -(nothing yet) +- #97 Unref rotating-file timeout which was preventing processes from exiting ## bunyan 0.22.1