Buckets:
ktongue/docker_container / .cache /opencode /node_modules /fastify /test /diagnostics-channel /error-status.test.js
| const { test } = require('node:test') | |
| const Fastify = require('../..') | |
| const statusCodes = require('node:http').STATUS_CODES | |
| const diagnostics = require('node:diagnostics_channel') | |
| test('diagnostics channel error event should report correct status code', async (t) => { | |
| t.plan(3) | |
| const fastify = Fastify() | |
| t.after(() => fastify.close()) | |
| let diagnosticsStatusCode | |
| const channel = diagnostics.channel('tracing:fastify.request.handler:error') | |
| const handler = (msg) => { | |
| diagnosticsStatusCode = msg.reply.statusCode | |
| } | |
| channel.subscribe(handler) | |
| t.after(() => channel.unsubscribe(handler)) | |
| fastify.get('/', async () => { | |
| const err = new Error('test error') | |
| err.statusCode = 503 | |
| throw err | |
| }) | |
| const res = await fastify.inject('/') | |
| t.assert.strictEqual(res.statusCode, 503) | |
| t.assert.strictEqual(diagnosticsStatusCode, 503, 'diagnostics channel should report correct status code') | |
| t.assert.strictEqual(diagnosticsStatusCode, res.statusCode, 'diagnostics status should match response status') | |
| }) | |
| test('diagnostics channel error event should report 500 for errors without status', async (t) => { | |
| t.plan(3) | |
| const fastify = Fastify() | |
| t.after(() => fastify.close()) | |
| let diagnosticsStatusCode | |
| const channel = diagnostics.channel('tracing:fastify.request.handler:error') | |
| const handler = (msg) => { | |
| diagnosticsStatusCode = msg.reply.statusCode | |
| } | |
| channel.subscribe(handler) | |
| t.after(() => channel.unsubscribe(handler)) | |
| fastify.get('/', async () => { | |
| throw new Error('plain error without status') | |
| }) | |
| const res = await fastify.inject('/') | |
| t.assert.strictEqual(res.statusCode, 500) | |
| t.assert.strictEqual(diagnosticsStatusCode, 500, 'diagnostics channel should report 500 for plain errors') | |
| t.assert.strictEqual(diagnosticsStatusCode, res.statusCode, 'diagnostics status should match response status') | |
| }) | |
| test('diagnostics channel error event should report correct status with custom error handler', async (t) => { | |
| t.plan(3) | |
| const fastify = Fastify() | |
| t.after(() => fastify.close()) | |
| let diagnosticsStatusCode | |
| const channel = diagnostics.channel('tracing:fastify.request.handler:error') | |
| const handler = (msg) => { | |
| diagnosticsStatusCode = msg.reply.statusCode | |
| } | |
| channel.subscribe(handler) | |
| t.after(() => channel.unsubscribe(handler)) | |
| fastify.setErrorHandler((error, request, reply) => { | |
| reply.status(503).send({ error: error.message }) | |
| }) | |
| fastify.get('/', async () => { | |
| throw new Error('handler error') | |
| }) | |
| const res = await fastify.inject('/') | |
| // Note: The diagnostics channel fires before the custom error handler runs, | |
| // so it reports 500 (default) rather than 503 (set by custom handler). | |
| // This is expected behavior - the error channel reports the initial error state. | |
| t.assert.strictEqual(res.statusCode, 503) | |
| t.assert.strictEqual(diagnosticsStatusCode, 500, 'diagnostics channel reports status before custom handler') | |
| t.assert.notStrictEqual(diagnosticsStatusCode, res.statusCode, 'custom handler can change status after diagnostics') | |
| }) | |
| test('Error.status property support', (t, done) => { | |
| t.plan(4) | |
| const fastify = Fastify() | |
| t.after(() => fastify.close()) | |
| const err = new Error('winter is coming') | |
| err.status = 418 | |
| diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => { | |
| t.assert.strictEqual(msg.error.message, 'winter is coming') | |
| }) | |
| fastify.get('/', () => { | |
| return Promise.reject(err) | |
| }) | |
| fastify.inject({ | |
| method: 'GET', | |
| url: '/' | |
| }, (error, res) => { | |
| t.assert.ifError(error) | |
| t.assert.strictEqual(res.statusCode, 418) | |
| t.assert.deepStrictEqual( | |
| { | |
| error: statusCodes['418'], | |
| message: err.message, | |
| statusCode: 418 | |
| }, | |
| JSON.parse(res.payload) | |
| ) | |
| done() | |
| }) | |
| }) | |
Xet Storage Details
- Size:
- 3.83 kB
- Xet hash:
- fb12b418f60d8f9b7c9ac512440ccdc2a73299e87c08daf278dfb3c99082c411
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.