From cda27589dd4ca196f5885aa4888961242cfff938 Mon Sep 17 00:00:00 2001 From: Matteo Collina Date: Tue, 15 Oct 2024 16:14:30 +0200 Subject: [PATCH] wait for destination to close Signed-off-by: Matteo Collina --- index.js | 12 +++++++++--- test/basic.test.js | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 3 deletions(-) diff --git a/index.js b/index.js index d34c194..e085c67 100644 --- a/index.js +++ b/index.js @@ -131,6 +131,7 @@ function prettyFactory (options) { */ function build (opts = {}) { let pretty = prettyFactory(opts) + let destination return abstractTransport(function (source) { source.on('message', function pinoConfigListener (message) { if (!message || message.code !== 'PINO_CONFIG') return @@ -151,8 +152,6 @@ function build (opts = {}) { } }) - let destination - if (typeof opts.destination === 'object' && typeof opts.destination.write === 'function') { destination = opts.destination } else { @@ -170,7 +169,14 @@ function build (opts = {}) { pump(source, stream, destination, () => {}) return stream - }, { parse: 'lines' }) + }, { + parse: 'lines', + close (err, cb) { + destination.on('close', () => { + cb(err) + }) + } + }) } module.exports = build diff --git a/test/basic.test.js b/test/basic.test.js index 89514f5..a62abbf 100644 --- a/test/basic.test.js +++ b/test/basic.test.js @@ -1098,6 +1098,38 @@ test('basic prettifier tests', (t) => { t.equal(closeCalled, false) }) + t.test('wait for close event from destination', (t) => { + t.plan(2) + const destination = pino.destination({ minLength: 4096, sync: true }) + const prettyDestination = pinoPretty({ destination, colorize: false }) + const log = pino(prettyDestination) + log.info('this message has been buffered') + const chunks = [] + const { close, writeSync } = fs + fs.close = new Proxy(close, { + apply: (target, self, args) => { + } + }) + fs.writeSync = new Proxy(writeSync, { + apply: (target, self, args) => { + chunks.push(args[1]) + return args[1].length + } + }) + t.teardown(() => { + Object.assign(fs, { close, writeSync }) + }) + let destinationClosed = false + destination.on('close', () => { + destinationClosed = true + }) + prettyDestination.on('close', () => { + t.match(chunks.join(''), /INFO .+: this message has been buffered/) + t.equal(destinationClosed, true) + }) + prettyDestination.end() + }) + t.test('stream usage', async (t) => { t.plan(1) const tmpDir = path.join(__dirname, '.tmp_' + Date.now())