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