Projektstart
This commit is contained in:
116
backend/node_modules/fastify/test/maxRequestsPerSocket.test.js
generated
vendored
Normal file
116
backend/node_modules/fastify/test/maxRequestsPerSocket.test.js
generated
vendored
Normal file
@@ -0,0 +1,116 @@
|
||||
'use strict'
|
||||
|
||||
const net = require('node:net')
|
||||
const { test } = require('tap')
|
||||
const semver = require('semver')
|
||||
const Fastify = require('../fastify')
|
||||
|
||||
const skip = semver.lt(process.versions.node, '16.10.0')
|
||||
|
||||
test('maxRequestsPerSocket on node version >= 16.10.0', { skip }, t => {
|
||||
t.plan(8)
|
||||
|
||||
const fastify = Fastify({ maxRequestsPerSocket: 2 })
|
||||
fastify.get('/', (req, reply) => {
|
||||
reply.send({ hello: 'world' })
|
||||
})
|
||||
|
||||
t.teardown(fastify.close.bind(fastify))
|
||||
|
||||
fastify.listen({ port: 0 }, function (err) {
|
||||
t.error(err)
|
||||
|
||||
const port = fastify.server.address().port
|
||||
const client = net.createConnection({ port }, () => {
|
||||
client.write('GET / HTTP/1.1\r\nHost: example.com\r\n\r\n')
|
||||
|
||||
client.once('data', data => {
|
||||
t.match(data.toString(), /Connection:\s*keep-alive/i)
|
||||
t.match(data.toString(), /Keep-Alive:\s*timeout=\d+/i)
|
||||
t.match(data.toString(), /200 OK/i)
|
||||
|
||||
client.write('GET / HTTP/1.1\r\nHost: example.com\r\n\r\n')
|
||||
|
||||
client.once('data', data => {
|
||||
t.match(data.toString(), /Connection:\s*close/i)
|
||||
t.match(data.toString(), /200 OK/i)
|
||||
|
||||
client.write('GET / HTTP/1.1\r\nHost: example.com\r\n\r\n')
|
||||
|
||||
client.once('data', data => {
|
||||
t.match(data.toString(), /Connection:\s*close/i)
|
||||
t.match(data.toString(), /503 Service Unavailable/i)
|
||||
client.end()
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
test('maxRequestsPerSocket zero should behave same as null', { skip }, t => {
|
||||
t.plan(10)
|
||||
|
||||
const fastify = Fastify({ maxRequestsPerSocket: 0 })
|
||||
fastify.get('/', (req, reply) => {
|
||||
reply.send({ hello: 'world' })
|
||||
})
|
||||
|
||||
t.teardown(fastify.close.bind(fastify))
|
||||
|
||||
fastify.listen({ port: 0 }, function (err) {
|
||||
t.error(err)
|
||||
|
||||
const port = fastify.server.address().port
|
||||
const client = net.createConnection({ port }, () => {
|
||||
client.write('GET / HTTP/1.1\r\nHost: example.com\r\n\r\n')
|
||||
|
||||
client.once('data', data => {
|
||||
t.match(data.toString(), /Connection:\s*keep-alive/i)
|
||||
t.match(data.toString(), /Keep-Alive:\s*timeout=\d+/i)
|
||||
t.match(data.toString(), /200 OK/i)
|
||||
|
||||
client.write('GET / HTTP/1.1\r\nHost: example.com\r\n\r\n')
|
||||
|
||||
client.once('data', data => {
|
||||
t.match(data.toString(), /Connection:\s*keep-alive/i)
|
||||
t.match(data.toString(), /Keep-Alive:\s*timeout=\d+/i)
|
||||
t.match(data.toString(), /200 OK/i)
|
||||
|
||||
client.write('GET / HTTP/1.1\r\nHost: example.com\r\n\r\n')
|
||||
|
||||
client.once('data', data => {
|
||||
t.match(data.toString(), /Connection:\s*keep-alive/i)
|
||||
t.match(data.toString(), /Keep-Alive:\s*timeout=\d+/i)
|
||||
t.match(data.toString(), /200 OK/i)
|
||||
client.end()
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
test('maxRequestsPerSocket should be set', async (t) => {
|
||||
t.plan(1)
|
||||
|
||||
const initialConfig = Fastify({ maxRequestsPerSocket: 5 }).initialConfig
|
||||
t.same(initialConfig.maxRequestsPerSocket, 5)
|
||||
})
|
||||
|
||||
test('maxRequestsPerSocket should 0', async (t) => {
|
||||
t.plan(1)
|
||||
|
||||
const initialConfig = Fastify().initialConfig
|
||||
t.same(initialConfig.maxRequestsPerSocket, 0)
|
||||
})
|
||||
|
||||
test('requestTimeout passed to server', t => {
|
||||
t.plan(2)
|
||||
|
||||
const httpServer = Fastify({ maxRequestsPerSocket: 5 }).server
|
||||
t.equal(httpServer.maxRequestsPerSocket, 5)
|
||||
|
||||
const httpsServer = Fastify({ maxRequestsPerSocket: 5, https: true }).server
|
||||
t.equal(httpsServer.maxRequestsPerSocket, 5)
|
||||
})
|
||||
Reference in New Issue
Block a user