fastify
Version: 
Fast and low overhead web framework, for Node.js
114 lines (85 loc) • 3.32 kB
JavaScript
const net = require('node:net')
const { test } = require('tap')
const Fastify = require('../fastify')
test('maxRequestsPerSocket', 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', 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)
})