You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					69 lines
				
				1.7 KiB
			
		
		
			
		
	
	
					69 lines
				
				1.7 KiB
			| 
											3 years ago
										 | 'use strict' | ||
|  | 
 | ||
|  | const { test } = require('tap') | ||
|  | const { join } = require('path') | ||
|  | const execa = require('execa') | ||
|  | const writer = require('flush-write-stream') | ||
|  | const { once } = require('./helper') | ||
|  | 
 | ||
|  | // https://github.com/pinojs/pino/issues/542
 | ||
|  | test('pino.destination log everything when calling process.exit(0)', async ({ not }) => { | ||
|  |   let actual = '' | ||
|  |   const child = execa(process.argv[0], [join(__dirname, 'fixtures', 'destination-exit.js')]) | ||
|  | 
 | ||
|  |   child.stdout.pipe(writer((s, enc, cb) => { | ||
|  |     actual += s | ||
|  |     cb() | ||
|  |   })) | ||
|  | 
 | ||
|  |   await once(child, 'close') | ||
|  | 
 | ||
|  |   not(actual.match(/hello/), null) | ||
|  |   not(actual.match(/world/), null) | ||
|  | }) | ||
|  | 
 | ||
|  | test('pino with no args log everything when calling process.exit(0)', async ({ not }) => { | ||
|  |   let actual = '' | ||
|  |   const child = execa(process.argv[0], [join(__dirname, 'fixtures', 'default-exit.js')]) | ||
|  | 
 | ||
|  |   child.stdout.pipe(writer((s, enc, cb) => { | ||
|  |     actual += s | ||
|  |     cb() | ||
|  |   })) | ||
|  | 
 | ||
|  |   await once(child, 'close') | ||
|  | 
 | ||
|  |   not(actual.match(/hello/), null) | ||
|  |   not(actual.match(/world/), null) | ||
|  | }) | ||
|  | 
 | ||
|  | test('sync false does not log everything when calling process.exit(0)', async ({ equal }) => { | ||
|  |   let actual = '' | ||
|  |   const child = execa(process.argv[0], [join(__dirname, 'fixtures', 'syncfalse-exit.js')]) | ||
|  | 
 | ||
|  |   child.stdout.pipe(writer((s, enc, cb) => { | ||
|  |     actual += s | ||
|  |     cb() | ||
|  |   })) | ||
|  | 
 | ||
|  |   await once(child, 'close') | ||
|  | 
 | ||
|  |   equal(actual.match(/hello/), null) | ||
|  |   equal(actual.match(/world/), null) | ||
|  | }) | ||
|  | 
 | ||
|  | test('sync false logs everything when calling flushSync', async ({ not }) => { | ||
|  |   let actual = '' | ||
|  |   const child = execa(process.argv[0], [join(__dirname, 'fixtures', 'syncfalse-flush-exit.js')]) | ||
|  | 
 | ||
|  |   child.stdout.pipe(writer((s, enc, cb) => { | ||
|  |     actual += s | ||
|  |     cb() | ||
|  |   })) | ||
|  | 
 | ||
|  |   await once(child, 'close') | ||
|  | 
 | ||
|  |   not(actual.match(/hello/), null) | ||
|  |   not(actual.match(/world/), null) | ||
|  | }) |