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.
		
		
		
		
		
			
		
			
				
					98 lines
				
				2.1 KiB
			
		
		
			
		
	
	
					98 lines
				
				2.1 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								'use strict'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const tap = require('tap')
							 | 
						||
| 
								 | 
							
								const { sink, once } = require('./helper')
							 | 
						||
| 
								 | 
							
								const pino = require('../')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								tap.test('log method hook', t => {
							 | 
						||
| 
								 | 
							
								  t.test('gets invoked', async t => {
							 | 
						||
| 
								 | 
							
								    t.plan(8)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const stream = sink()
							 | 
						||
| 
								 | 
							
								    const logger = pino({
							 | 
						||
| 
								 | 
							
								      hooks: {
							 | 
						||
| 
								 | 
							
								        logMethod (args, method, level) {
							 | 
						||
| 
								 | 
							
								          t.type(args, Array)
							 | 
						||
| 
								 | 
							
								          t.type(level, 'number')
							 | 
						||
| 
								 | 
							
								          t.equal(args.length, 3)
							 | 
						||
| 
								 | 
							
								          t.equal(level, this.levels.values.info)
							 | 
						||
| 
								 | 
							
								          t.same(args, ['a', 'b', 'c'])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          t.type(method, Function)
							 | 
						||
| 
								 | 
							
								          t.equal(method.name, 'LOG')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          method.apply(this, [args.join('-')])
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const o = once(stream, 'data')
							 | 
						||
| 
								 | 
							
								    logger.info('a', 'b', 'c')
							 | 
						||
| 
								 | 
							
								    t.match(await o, { msg: 'a-b-c' })
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  t.test('fatal method invokes hook', async t => {
							 | 
						||
| 
								 | 
							
								    t.plan(2)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const stream = sink()
							 | 
						||
| 
								 | 
							
								    const logger = pino({
							 | 
						||
| 
								 | 
							
								      hooks: {
							 | 
						||
| 
								 | 
							
								        logMethod (args, method) {
							 | 
						||
| 
								 | 
							
								          t.pass()
							 | 
						||
| 
								 | 
							
								          method.apply(this, [args.join('-')])
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const o = once(stream, 'data')
							 | 
						||
| 
								 | 
							
								    logger.fatal('a')
							 | 
						||
| 
								 | 
							
								    t.match(await o, { msg: 'a' })
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  t.test('children get the hook', async t => {
							 | 
						||
| 
								 | 
							
								    t.plan(4)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const stream = sink()
							 | 
						||
| 
								 | 
							
								    const root = pino({
							 | 
						||
| 
								 | 
							
								      hooks: {
							 | 
						||
| 
								 | 
							
								        logMethod (args, method) {
							 | 
						||
| 
								 | 
							
								          t.pass()
							 | 
						||
| 
								 | 
							
								          method.apply(this, [args.join('-')])
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }, stream)
							 | 
						||
| 
								 | 
							
								    const child = root.child({ child: 'one' })
							 | 
						||
| 
								 | 
							
								    const grandchild = child.child({ child: 'two' })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    let o = once(stream, 'data')
							 | 
						||
| 
								 | 
							
								    child.info('a', 'b')
							 | 
						||
| 
								 | 
							
								    t.match(await o, { msg: 'a-b' })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    o = once(stream, 'data')
							 | 
						||
| 
								 | 
							
								    grandchild.info('c', 'd')
							 | 
						||
| 
								 | 
							
								    t.match(await o, { msg: 'c-d' })
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  t.test('get log level', async t => {
							 | 
						||
| 
								 | 
							
								    t.plan(3)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const stream = sink()
							 | 
						||
| 
								 | 
							
								    const logger = pino({
							 | 
						||
| 
								 | 
							
								      hooks: {
							 | 
						||
| 
								 | 
							
								        logMethod (args, method, level) {
							 | 
						||
| 
								 | 
							
								          t.type(level, 'number')
							 | 
						||
| 
								 | 
							
								          t.equal(level, this.levels.values.error)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          method.apply(this, [args.join('-')])
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const o = once(stream, 'data')
							 | 
						||
| 
								 | 
							
								    logger.error('a')
							 | 
						||
| 
								 | 
							
								    t.match(await o, { msg: 'a' })
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  t.end()
							 | 
						||
| 
								 | 
							
								})
							 |