summaryrefslogtreecommitdiff
path: root/test/parallel/test-http-slow-headers-keepalive-multiple-requests.js
blob: 9ea76e8e56e95206a750af6d6edfafc4c3f6b65a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
'use strict';

const common = require('../common');
const http = require('http');
const net = require('net');
const { finished } = require('stream');

const headers =
  'GET / HTTP/1.1\r\n' +
  'Host: localhost\r\n' +
  'Connection: keep-alive\r\n' +
  'Agent: node\r\n';

const baseTimeout = 1000;

const server = http.createServer(common.mustCall((req, res) => {
  req.resume();
  res.writeHead(200);
  res.end();
}, 2));

server.keepAliveTimeout = 10 * baseTimeout;
server.headersTimeout = baseTimeout;

server.once('timeout', common.mustNotCall((socket) => {
  socket.destroy();
}));

server.listen(0, () => {
  const client = net.connect(server.address().port);

  // first request
  client.write(headers);
  client.write('\r\n');

  setTimeout(() => {
    // second request
    client.write(headers);
    // `headersTimeout` doesn't seem to fire if request
    // is sent altogether.
    setTimeout(() => {
      client.write('\r\n');
      client.end();
    }, 10);
  }, baseTimeout + 10);

  client.resume();
  finished(client, common.mustCall((err) => {
    server.close();
  }));
});