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.
		
		
		
		
		
			
		
			
				
					
					
						
							135 lines
						
					
					
						
							2.8 KiB
						
					
					
				
			
		
		
	
	
							135 lines
						
					
					
						
							2.8 KiB
						
					
					
				'use strict'
 | 
						|
 | 
						|
const t = require('tap')
 | 
						|
const test = t.test
 | 
						|
const Fastify = require('../..')
 | 
						|
const loggerUtils = require('../../lib/logger')
 | 
						|
 | 
						|
test('time resolution', t => {
 | 
						|
  t.plan(2)
 | 
						|
  t.equal(typeof loggerUtils.now, 'function')
 | 
						|
  t.equal(typeof loggerUtils.now(), 'number')
 | 
						|
})
 | 
						|
 | 
						|
test('The logger should add a unique id for every request', t => {
 | 
						|
  const ids = []
 | 
						|
 | 
						|
  const fastify = Fastify()
 | 
						|
  fastify.get('/', (req, reply) => {
 | 
						|
    t.ok(req.id)
 | 
						|
    reply.send({ id: req.id })
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, err => {
 | 
						|
    t.error(err)
 | 
						|
    const queue = new Queue()
 | 
						|
    for (let i = 0; i < 10; i++) {
 | 
						|
      queue.add(checkId)
 | 
						|
    }
 | 
						|
    queue.add(() => {
 | 
						|
      fastify.close()
 | 
						|
      t.end()
 | 
						|
    })
 | 
						|
  })
 | 
						|
 | 
						|
  function checkId (done) {
 | 
						|
    fastify.inject({
 | 
						|
      method: 'GET',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port
 | 
						|
    }, (err, res) => {
 | 
						|
      t.error(err)
 | 
						|
      const payload = JSON.parse(res.payload)
 | 
						|
      t.ok(ids.indexOf(payload.id) === -1, 'the id should not be duplicated')
 | 
						|
      ids.push(payload.id)
 | 
						|
      done()
 | 
						|
    })
 | 
						|
  }
 | 
						|
})
 | 
						|
 | 
						|
test('The logger should reuse request id header for req.id', t => {
 | 
						|
  const fastify = Fastify()
 | 
						|
  fastify.get('/', (req, reply) => {
 | 
						|
    t.ok(req.id)
 | 
						|
    reply.send({ id: req.id })
 | 
						|
  })
 | 
						|
 | 
						|
  fastify.listen(0, err => {
 | 
						|
    t.error(err)
 | 
						|
 | 
						|
    fastify.inject({
 | 
						|
      method: 'GET',
 | 
						|
      url: 'http://localhost:' + fastify.server.address().port,
 | 
						|
      headers: {
 | 
						|
        'Request-Id': 'request-id-1'
 | 
						|
      }
 | 
						|
    }, (err, res) => {
 | 
						|
      t.error(err)
 | 
						|
      const payload = JSON.parse(res.payload)
 | 
						|
      t.ok(payload.id === 'request-id-1', 'the request id from the header should be returned')
 | 
						|
      fastify.close()
 | 
						|
      t.end()
 | 
						|
    })
 | 
						|
  })
 | 
						|
})
 | 
						|
 | 
						|
function Queue () {
 | 
						|
  this.q = []
 | 
						|
  this.running = false
 | 
						|
}
 | 
						|
 | 
						|
Queue.prototype.add = function add (job) {
 | 
						|
  this.q.push(job)
 | 
						|
  if (!this.running) this.run()
 | 
						|
}
 | 
						|
 | 
						|
Queue.prototype.run = function run () {
 | 
						|
  this.running = true
 | 
						|
  const job = this.q.shift()
 | 
						|
  job(() => {
 | 
						|
    if (this.q.length) {
 | 
						|
      this.run()
 | 
						|
    } else {
 | 
						|
      this.running = false
 | 
						|
    }
 | 
						|
  })
 | 
						|
}
 | 
						|
 | 
						|
test('The logger should error if both stream and file destination are given', t => {
 | 
						|
  t.plan(2)
 | 
						|
 | 
						|
  const stream = require('stream').Writable
 | 
						|
 | 
						|
  try {
 | 
						|
    Fastify({
 | 
						|
      logger: {
 | 
						|
        level: 'info',
 | 
						|
        stream,
 | 
						|
        file: '/test'
 | 
						|
      }
 | 
						|
    })
 | 
						|
  } catch (err) {
 | 
						|
    t.equal(err.code, 'FST_ERR_LOG_INVALID_DESTINATION')
 | 
						|
    t.equal(err.message, 'Cannot specify both logger.stream and logger.file options')
 | 
						|
  }
 | 
						|
})
 | 
						|
 | 
						|
test('The serializer prevent fails if the request socket is undefined', t => {
 | 
						|
  t.plan(1)
 | 
						|
 | 
						|
  const serialized = loggerUtils.serializers.req({
 | 
						|
    method: 'GET',
 | 
						|
    url: '/',
 | 
						|
    socket: undefined,
 | 
						|
    headers: {}
 | 
						|
  })
 | 
						|
 | 
						|
  t.same(serialized, {
 | 
						|
    method: 'GET',
 | 
						|
    url: '/',
 | 
						|
    version: undefined,
 | 
						|
    hostname: undefined,
 | 
						|
    remoteAddress: undefined,
 | 
						|
    remotePort: undefined
 | 
						|
  })
 | 
						|
})
 |