232 lines
5.2 KiB
JavaScript
232 lines
5.2 KiB
JavaScript
'use strict'
|
|
|
|
const { test } = require('node:test')
|
|
const Fastify = require('..')
|
|
const symbols = require('../lib/symbols.js')
|
|
|
|
test('default 500', (t, done) => {
|
|
t.plan(4)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.get('/', function (req, reply) {
|
|
reply.send(new Error('kaboom'))
|
|
})
|
|
|
|
fastify.inject({
|
|
method: 'GET',
|
|
url: '/'
|
|
}, (err, res) => {
|
|
t.assert.ifError(err)
|
|
t.assert.strictEqual(res.statusCode, 500)
|
|
t.assert.strictEqual(res.headers['content-type'], 'application/json; charset=utf-8')
|
|
t.assert.deepStrictEqual(JSON.parse(res.payload), {
|
|
error: 'Internal Server Error',
|
|
message: 'kaboom',
|
|
statusCode: 500
|
|
})
|
|
done()
|
|
})
|
|
})
|
|
|
|
test('custom 500', (t, done) => {
|
|
t.plan(6)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.get('/', function (req, reply) {
|
|
reply.send(new Error('kaboom'))
|
|
})
|
|
|
|
fastify.setErrorHandler(function (err, request, reply) {
|
|
t.assert.ok(typeof request === 'object')
|
|
t.assert.ok(request instanceof fastify[symbols.kRequest].parent)
|
|
reply
|
|
.code(500)
|
|
.type('text/plain')
|
|
.send('an error happened: ' + err.message)
|
|
})
|
|
|
|
fastify.inject({
|
|
method: 'GET',
|
|
url: '/'
|
|
}, (err, res) => {
|
|
t.assert.ifError(err)
|
|
t.assert.strictEqual(res.statusCode, 500)
|
|
t.assert.strictEqual(res.headers['content-type'], 'text/plain')
|
|
t.assert.deepStrictEqual(res.payload.toString(), 'an error happened: kaboom')
|
|
done()
|
|
})
|
|
})
|
|
|
|
test('encapsulated 500', async t => {
|
|
t.plan(8)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.get('/', function (req, reply) {
|
|
reply.send(new Error('kaboom'))
|
|
})
|
|
|
|
fastify.register(function (f, opts, done) {
|
|
f.get('/', function (req, reply) {
|
|
reply.send(new Error('kaboom'))
|
|
})
|
|
|
|
f.setErrorHandler(function (err, request, reply) {
|
|
t.assert.ok(typeof request === 'object')
|
|
t.assert.ok(request instanceof fastify[symbols.kRequest].parent)
|
|
reply
|
|
.code(500)
|
|
.type('text/plain')
|
|
.send('an error happened: ' + err.message)
|
|
})
|
|
|
|
done()
|
|
}, { prefix: 'test' })
|
|
|
|
{
|
|
const response = await fastify.inject({
|
|
method: 'GET',
|
|
url: '/test'
|
|
})
|
|
|
|
t.assert.strictEqual(response.statusCode, 500)
|
|
t.assert.strictEqual(response.headers['content-type'], 'text/plain')
|
|
t.assert.deepStrictEqual(response.payload.toString(), 'an error happened: kaboom')
|
|
}
|
|
|
|
{
|
|
const response = await fastify.inject({
|
|
method: 'GET',
|
|
url: '/'
|
|
})
|
|
|
|
t.assert.strictEqual(response.statusCode, 500)
|
|
t.assert.strictEqual(response.headers['content-type'], 'application/json; charset=utf-8')
|
|
t.assert.deepStrictEqual(JSON.parse(response.payload), {
|
|
error: 'Internal Server Error',
|
|
message: 'kaboom',
|
|
statusCode: 500
|
|
})
|
|
}
|
|
})
|
|
|
|
test('custom 500 with hooks', (t, done) => {
|
|
t.plan(7)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.get('/', function (req, reply) {
|
|
reply.send(new Error('kaboom'))
|
|
})
|
|
|
|
fastify.setErrorHandler(function (err, request, reply) {
|
|
reply
|
|
.code(500)
|
|
.type('text/plain')
|
|
.send('an error happened: ' + err.message)
|
|
})
|
|
|
|
fastify.addHook('onSend', (req, res, payload, done) => {
|
|
t.assert.ok('called', 'onSend')
|
|
done()
|
|
})
|
|
fastify.addHook('onRequest', (req, res, done) => {
|
|
t.assert.ok('called', 'onRequest')
|
|
done()
|
|
})
|
|
fastify.addHook('onResponse', (request, reply, done) => {
|
|
t.assert.ok('called', 'onResponse')
|
|
done()
|
|
})
|
|
|
|
fastify.inject({
|
|
method: 'GET',
|
|
url: '/'
|
|
}, (err, res) => {
|
|
t.assert.ifError(err)
|
|
t.assert.strictEqual(res.statusCode, 500)
|
|
t.assert.strictEqual(res.headers['content-type'], 'text/plain')
|
|
t.assert.deepStrictEqual(res.payload.toString(), 'an error happened: kaboom')
|
|
done()
|
|
})
|
|
})
|
|
|
|
test('cannot set errorHandler after binding', (t, done) => {
|
|
t.plan(2)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.listen({ port: 0 }, err => {
|
|
t.assert.ifError(err)
|
|
|
|
try {
|
|
fastify.setErrorHandler(() => { })
|
|
t.assert.fail()
|
|
} catch (e) {
|
|
t.assert.ok(true)
|
|
} finally {
|
|
done()
|
|
}
|
|
})
|
|
})
|
|
|
|
test('cannot set childLoggerFactory after binding', (t, done) => {
|
|
t.plan(2)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.listen({ port: 0 }, err => {
|
|
t.assert.ifError(err)
|
|
|
|
try {
|
|
fastify.setChildLoggerFactory(() => { })
|
|
t.assert.fail()
|
|
} catch (e) {
|
|
t.assert.ok(true)
|
|
} finally {
|
|
done()
|
|
}
|
|
})
|
|
})
|
|
|
|
test('catch synchronous errors', (t, done) => {
|
|
t.plan(3)
|
|
|
|
const fastify = Fastify()
|
|
t.after(() => fastify.close())
|
|
|
|
fastify.setErrorHandler((_, req, reply) => {
|
|
throw new Error('kaboom2')
|
|
})
|
|
|
|
fastify.post('/', function (req, reply) {
|
|
reply.send(new Error('kaboom'))
|
|
})
|
|
|
|
fastify.inject({
|
|
method: 'POST',
|
|
url: '/',
|
|
headers: {
|
|
'Content-Type': 'application/json'
|
|
},
|
|
payload: JSON.stringify({ hello: 'world' }).substring(0, 5)
|
|
}, (err, res) => {
|
|
t.assert.ifError(err)
|
|
t.assert.strictEqual(res.statusCode, 500)
|
|
t.assert.deepStrictEqual(res.json(), {
|
|
error: 'Internal Server Error',
|
|
message: 'kaboom2',
|
|
statusCode: 500
|
|
})
|
|
done()
|
|
})
|
|
})
|