fatsify核心功能示例测试!!!
This commit is contained in:
49
node_modules/fastify/test/diagnostics-channel/404.test.js
generated
vendored
Normal file
49
node_modules/fastify/test/diagnostics-channel/404.test.js
generated
vendored
Normal file
@@ -0,0 +1,49 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel sync events fire in expected order', async t => {
|
||||
t.plan(9)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.fail('should not trigger error channel')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/',
|
||||
handler: function (req, reply) {
|
||||
reply.callNotFound()
|
||||
}
|
||||
})
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const response = await fetch(fastifyServer, {
|
||||
method: 'GET'
|
||||
})
|
||||
t.assert.ok(!response.ok)
|
||||
t.assert.strictEqual(response.status, 404)
|
||||
})
|
||||
65
node_modules/fastify/test/diagnostics-channel/async-delay-request.test.js
generated
vendored
Normal file
65
node_modules/fastify/test/diagnostics-channel/async-delay-request.test.js
generated
vendored
Normal file
@@ -0,0 +1,65 @@
|
||||
'use strict'
|
||||
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const { test } = require('node:test')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel async events fire in expected order', async t => {
|
||||
t.plan(19)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
t.assert.strictEqual(msg.async, true)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:asyncStart', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 2)
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:asyncEnd', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 3)
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.fail('should not trigger error channel')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/',
|
||||
handler: async function (req, reply) {
|
||||
setImmediate(() => reply.send({ hello: 'world' }))
|
||||
return reply
|
||||
}
|
||||
})
|
||||
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
|
||||
const result = await fetch(fastifyServer + '/')
|
||||
t.assert.ok(result.ok)
|
||||
t.assert.strictEqual(result.status, 200)
|
||||
t.assert.deepStrictEqual(await result.json(), { hello: 'world' })
|
||||
})
|
||||
64
node_modules/fastify/test/diagnostics-channel/async-request.test.js
generated
vendored
Normal file
64
node_modules/fastify/test/diagnostics-channel/async-request.test.js
generated
vendored
Normal file
@@ -0,0 +1,64 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel async events fire in expected order', async t => {
|
||||
t.plan(18)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:asyncStart', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 2)
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:asyncEnd', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 3)
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.fail('should not trigger error channel')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/',
|
||||
handler: async function (req, reply) {
|
||||
return { hello: 'world' }
|
||||
}
|
||||
})
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const response = await fetch(fastifyServer)
|
||||
t.assert.ok(response.ok)
|
||||
t.assert.strictEqual(response.status, 200)
|
||||
const body = await response.text()
|
||||
t.assert.deepStrictEqual(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
35
node_modules/fastify/test/diagnostics-channel/error-before-handler.test.js
generated
vendored
Normal file
35
node_modules/fastify/test/diagnostics-channel/error-before-handler.test.js
generated
vendored
Normal file
@@ -0,0 +1,35 @@
|
||||
'use strict'
|
||||
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const { test } = require('node:test')
|
||||
require('../../lib/hooks').onSendHookRunner = function Stub () {}
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
const symbols = require('../../lib/symbols.js')
|
||||
const { preHandlerCallback } = require('../../lib/handleRequest')[Symbol.for('internals')]
|
||||
|
||||
test('diagnostics channel handles an error before calling context handler', t => {
|
||||
t.plan(3)
|
||||
let callOrder = 0
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.strictEqual(msg.error.message, 'oh no')
|
||||
})
|
||||
|
||||
const error = new Error('oh no')
|
||||
const request = new Request()
|
||||
const reply = new Reply({}, request)
|
||||
request[symbols.kRouteContext] = {
|
||||
config: {
|
||||
url: '/foo',
|
||||
method: 'GET'
|
||||
}
|
||||
}
|
||||
|
||||
preHandlerCallback(error, request, reply)
|
||||
})
|
||||
53
node_modules/fastify/test/diagnostics-channel/error-request.test.js
generated
vendored
Normal file
53
node_modules/fastify/test/diagnostics-channel/error-request.test.js
generated
vendored
Normal file
@@ -0,0 +1,53 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel events report on errors', async t => {
|
||||
t.plan(14)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(callOrder++, 2)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.ok(msg.error instanceof Error)
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.strictEqual(msg.error.message, 'borked')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/',
|
||||
handler: function (req, reply) {
|
||||
throw new Error('borked')
|
||||
}
|
||||
})
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const response = await fetch(fastifyServer, {
|
||||
method: 'GET'
|
||||
})
|
||||
t.assert.ok(!response.ok)
|
||||
t.assert.strictEqual(response.status, 500)
|
||||
})
|
||||
39
node_modules/fastify/test/diagnostics-channel/error-status.test.js
generated
vendored
Normal file
39
node_modules/fastify/test/diagnostics-channel/error-status.test.js
generated
vendored
Normal file
@@ -0,0 +1,39 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const Fastify = require('../..')
|
||||
const statusCodes = require('node:http').STATUS_CODES
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
|
||||
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()
|
||||
})
|
||||
})
|
||||
50
node_modules/fastify/test/diagnostics-channel/init.test.js
generated
vendored
Normal file
50
node_modules/fastify/test/diagnostics-channel/init.test.js
generated
vendored
Normal file
@@ -0,0 +1,50 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const proxyquire = require('proxyquire')
|
||||
|
||||
test('diagnostics_channel when present and subscribers', t => {
|
||||
t.plan(3)
|
||||
|
||||
let fastifyInHook
|
||||
|
||||
const diagnostics = {
|
||||
channel (name) {
|
||||
t.assert.strictEqual(name, 'fastify.initialization')
|
||||
return {
|
||||
hasSubscribers: true,
|
||||
publish (event) {
|
||||
t.assert.ok(event.fastify)
|
||||
fastifyInHook = event.fastify
|
||||
}
|
||||
}
|
||||
},
|
||||
'@noCallThru': true
|
||||
}
|
||||
|
||||
const fastify = proxyquire('../../fastify', {
|
||||
'node:diagnostics_channel': diagnostics
|
||||
})()
|
||||
t.assert.strictEqual(fastifyInHook, fastify)
|
||||
})
|
||||
|
||||
test('diagnostics_channel when present and no subscribers', t => {
|
||||
t.plan(1)
|
||||
|
||||
const diagnostics = {
|
||||
channel (name) {
|
||||
t.assert.strictEqual(name, 'fastify.initialization')
|
||||
return {
|
||||
hasSubscribers: false,
|
||||
publish () {
|
||||
t.assert.fail('publish should not be called')
|
||||
}
|
||||
}
|
||||
},
|
||||
'@noCallThru': true
|
||||
}
|
||||
|
||||
proxyquire('../../fastify', {
|
||||
'node:diagnostics_channel': diagnostics
|
||||
})()
|
||||
})
|
||||
49
node_modules/fastify/test/diagnostics-channel/sync-delay-request.test.js
generated
vendored
Normal file
49
node_modules/fastify/test/diagnostics-channel/sync-delay-request.test.js
generated
vendored
Normal file
@@ -0,0 +1,49 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel sync events fire in expected order', async t => {
|
||||
t.plan(10)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.fail('should not trigger error channel')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/',
|
||||
handler: function (req, reply) {
|
||||
setImmediate(() => reply.send({ hello: 'world' }))
|
||||
}
|
||||
})
|
||||
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
|
||||
const result = await fetch(fastifyServer + '/')
|
||||
t.assert.ok(result.ok)
|
||||
t.assert.strictEqual(result.status, 200)
|
||||
t.assert.deepStrictEqual(await result.json(), { hello: 'world' })
|
||||
})
|
||||
51
node_modules/fastify/test/diagnostics-channel/sync-request-reply.test.js
generated
vendored
Normal file
51
node_modules/fastify/test/diagnostics-channel/sync-request-reply.test.js
generated
vendored
Normal file
@@ -0,0 +1,51 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel sync events fire in expected order', async t => {
|
||||
t.plan(10)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.fail('should not trigger error channel')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/',
|
||||
handler: function (req, reply) {
|
||||
reply.send({ hello: 'world' })
|
||||
}
|
||||
})
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const response = await fetch(fastifyServer, {
|
||||
method: 'GET'
|
||||
})
|
||||
t.assert.ok(response.ok)
|
||||
t.assert.strictEqual(response.status, 200)
|
||||
const body = await response.text()
|
||||
t.assert.deepStrictEqual(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
54
node_modules/fastify/test/diagnostics-channel/sync-request.test.js
generated
vendored
Normal file
54
node_modules/fastify/test/diagnostics-channel/sync-request.test.js
generated
vendored
Normal file
@@ -0,0 +1,54 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const diagnostics = require('node:diagnostics_channel')
|
||||
const Fastify = require('../..')
|
||||
const Request = require('../../lib/request')
|
||||
const Reply = require('../../lib/reply')
|
||||
|
||||
test('diagnostics channel sync events fire in expected order', async t => {
|
||||
t.plan(13)
|
||||
let callOrder = 0
|
||||
let firstEncounteredMessage
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:start', (msg) => {
|
||||
t.assert.strictEqual(callOrder++, 0)
|
||||
firstEncounteredMessage = msg
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.ok(msg.route)
|
||||
t.assert.strictEqual(msg.route.url, '/:id')
|
||||
t.assert.strictEqual(msg.route.method, 'GET')
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:end', (msg) => {
|
||||
t.assert.ok(msg.request instanceof Request)
|
||||
t.assert.ok(msg.reply instanceof Reply)
|
||||
t.assert.strictEqual(callOrder++, 1)
|
||||
t.assert.strictEqual(msg, firstEncounteredMessage)
|
||||
})
|
||||
|
||||
diagnostics.subscribe('tracing:fastify.request.handler:error', (msg) => {
|
||||
t.assert.fail('should not trigger error channel')
|
||||
})
|
||||
|
||||
const fastify = Fastify()
|
||||
fastify.route({
|
||||
method: 'GET',
|
||||
url: '/:id',
|
||||
handler: function (req, reply) {
|
||||
return { hello: 'world' }
|
||||
}
|
||||
})
|
||||
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
const response = await fetch(fastifyServer + '/7', {
|
||||
method: 'GET'
|
||||
})
|
||||
t.assert.ok(response.ok)
|
||||
t.assert.strictEqual(response.status, 200)
|
||||
const body = await response.text()
|
||||
t.assert.deepStrictEqual(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
Reference in New Issue
Block a user