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
						
					
					
				| '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)
 | |
| })
 |