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.
		
		
		
		
		
			
		
			
				
					295 lines
				
				6.7 KiB
			
		
		
			
		
	
	
					295 lines
				
				6.7 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								'use strict'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* eslint no-prototype-builtins: 0 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const { test } = require('tap')
							 | 
						||
| 
								 | 
							
								const { sink, once } = require('./helper')
							 | 
						||
| 
								 | 
							
								const pino = require('../')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Silence all warnings for this test
							 | 
						||
| 
								 | 
							
								process.removeAllListeners('warning')
							 | 
						||
| 
								 | 
							
								process.on('warning', () => {})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('adds additional levels', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35,
							 | 
						||
| 
								 | 
							
								      bar: 45
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.foo('test')
							 | 
						||
| 
								 | 
							
								  const { level } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(level, 35)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom levels does not override default levels', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.info('test')
							 | 
						||
| 
								 | 
							
								  const { level } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(level, 30)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('default levels can be redefined using custom levels', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      info: 35,
							 | 
						||
| 
								 | 
							
								      debug: 45
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    useOnlyCustomLevels: true
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  equal(logger.hasOwnProperty('info'), true)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.info('test')
							 | 
						||
| 
								 | 
							
								  const { level } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(level, 35)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom levels overrides default level label if use useOnlyCustomLevels', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    useOnlyCustomLevels: true,
							 | 
						||
| 
								 | 
							
								    level: 'foo'
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  equal(logger.hasOwnProperty('info'), false)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom levels overrides default level value if use useOnlyCustomLevels', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    useOnlyCustomLevels: true,
							 | 
						||
| 
								 | 
							
								    level: 35
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  equal(logger.hasOwnProperty('info'), false)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom levels are inherited by children', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.child({ childMsg: 'ok' }).foo('test')
							 | 
						||
| 
								 | 
							
								  const { msg, childMsg, level } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(level, 35)
							 | 
						||
| 
								 | 
							
								  equal(childMsg, 'ok')
							 | 
						||
| 
								 | 
							
								  equal(msg, 'test')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom levels can be specified on child bindings', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino(stream).child({
							 | 
						||
| 
								 | 
							
								    childMsg: 'ok'
							 | 
						||
| 
								 | 
							
								  }, {
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.foo('test')
							 | 
						||
| 
								 | 
							
								  const { msg, childMsg, level } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(level, 35)
							 | 
						||
| 
								 | 
							
								  equal(childMsg, 'ok')
							 | 
						||
| 
								 | 
							
								  equal(msg, 'test')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('customLevels property child bindings does not get logged', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino(stream).child({
							 | 
						||
| 
								 | 
							
								    childMsg: 'ok'
							 | 
						||
| 
								 | 
							
								  }, {
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.foo('test')
							 | 
						||
| 
								 | 
							
								  const { customLevels } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(customLevels, undefined)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('throws when specifying pre-existing parent labels via child bindings', async ({ throws }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  throws(() => pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream).child({}, {
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 45
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }), 'levels cannot be overridden')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('throws when specifying pre-existing parent values via child bindings', async ({ throws }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  throws(() => pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream).child({}, {
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      bar: 35
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }), 'pre-existing level values cannot be used for new levels')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('throws when specifying core values via child bindings', async ({ throws }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  throws(() => pino(stream).child({}, {
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 30
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }), 'pre-existing level values cannot be used for new levels')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('throws when useOnlyCustomLevels is set true without customLevels', async ({ throws }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  throws(() => pino({
							 | 
						||
| 
								 | 
							
								    useOnlyCustomLevels: true
							 | 
						||
| 
								 | 
							
								  }, stream), 'customLevels is required if useOnlyCustomLevels is set true')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom level on one instance does not affect other instances', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 37
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								  equal(typeof pino().foo, 'undefined')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('setting level below or at custom level will successfully log', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const instance = pino({ customLevels: { foo: 35 } }, stream)
							 | 
						||
| 
								 | 
							
								  instance.level = 'foo'
							 | 
						||
| 
								 | 
							
								  instance.info('nope')
							 | 
						||
| 
								 | 
							
								  instance.foo('bar')
							 | 
						||
| 
								 | 
							
								  const { msg } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(msg, 'bar')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom level below level threshold will not log', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const instance = pino({ customLevels: { foo: 15 } }, stream)
							 | 
						||
| 
								 | 
							
								  instance.level = 'info'
							 | 
						||
| 
								 | 
							
								  instance.info('bar')
							 | 
						||
| 
								 | 
							
								  instance.foo('nope')
							 | 
						||
| 
								 | 
							
								  const { msg } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(msg, 'bar')
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('does not share custom level state across siblings', async ({ doesNotThrow }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino(stream)
							 | 
						||
| 
								 | 
							
								  logger.child({}, {
							 | 
						||
| 
								 | 
							
								    customLevels: { foo: 35 }
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								  doesNotThrow(() => {
							 | 
						||
| 
								 | 
							
								    logger.child({}, {
							 | 
						||
| 
								 | 
							
								      customLevels: { foo: 35 }
							 | 
						||
| 
								 | 
							
								    })
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom level does not affect the levels serializer', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35,
							 | 
						||
| 
								 | 
							
								      bar: 45
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    formatters: {
							 | 
						||
| 
								 | 
							
								      level (label, number) {
							 | 
						||
| 
								 | 
							
								        return { priority: number }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.foo('test')
							 | 
						||
| 
								 | 
							
								  const { priority } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(priority, 35)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('When useOnlyCustomLevels is set to true, the level formatter should only get custom levels', async ({ equal }) => {
							 | 
						||
| 
								 | 
							
								  const stream = sink()
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      answer: 42
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    useOnlyCustomLevels: true,
							 | 
						||
| 
								 | 
							
								    level: 42,
							 | 
						||
| 
								 | 
							
								    formatters: {
							 | 
						||
| 
								 | 
							
								      level (label, number) {
							 | 
						||
| 
								 | 
							
								        equal(label, 'answer')
							 | 
						||
| 
								 | 
							
								        equal(number, 42)
							 | 
						||
| 
								 | 
							
								        return { level: number }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }, stream)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.answer('test')
							 | 
						||
| 
								 | 
							
								  const { level } = await once(stream, 'data')
							 | 
						||
| 
								 | 
							
								  equal(level, 42)
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test('custom levels accessible in prettifier function', async ({ plan, same }) => {
							 | 
						||
| 
								 | 
							
								  plan(1)
							 | 
						||
| 
								 | 
							
								  const logger = pino({
							 | 
						||
| 
								 | 
							
								    prettyPrint: true,
							 | 
						||
| 
								 | 
							
								    prettifier: function prettifierFactory () {
							 | 
						||
| 
								 | 
							
								      const instance = this
							 | 
						||
| 
								 | 
							
								      return function () {
							 | 
						||
| 
								 | 
							
								        same(instance.levels, {
							 | 
						||
| 
								 | 
							
								          labels: {
							 | 
						||
| 
								 | 
							
								            10: 'trace',
							 | 
						||
| 
								 | 
							
								            20: 'debug',
							 | 
						||
| 
								 | 
							
								            30: 'info',
							 | 
						||
| 
								 | 
							
								            35: 'foo',
							 | 
						||
| 
								 | 
							
								            40: 'warn',
							 | 
						||
| 
								 | 
							
								            45: 'bar',
							 | 
						||
| 
								 | 
							
								            50: 'error',
							 | 
						||
| 
								 | 
							
								            60: 'fatal'
							 | 
						||
| 
								 | 
							
								          },
							 | 
						||
| 
								 | 
							
								          values: {
							 | 
						||
| 
								 | 
							
								            trace: 10,
							 | 
						||
| 
								 | 
							
								            debug: 20,
							 | 
						||
| 
								 | 
							
								            info: 30,
							 | 
						||
| 
								 | 
							
								            warn: 40,
							 | 
						||
| 
								 | 
							
								            error: 50,
							 | 
						||
| 
								 | 
							
								            fatal: 60,
							 | 
						||
| 
								 | 
							
								            foo: 35,
							 | 
						||
| 
								 | 
							
								            bar: 45
							 | 
						||
| 
								 | 
							
								          }
							 | 
						||
| 
								 | 
							
								        })
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    customLevels: {
							 | 
						||
| 
								 | 
							
								      foo: 35,
							 | 
						||
| 
								 | 
							
								      bar: 45
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    changeLevelName: 'priority'
							 | 
						||
| 
								 | 
							
								  })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  logger.foo('test')
							 | 
						||
| 
								 | 
							
								})
							 |