summaryrefslogtreecommitdiff
path: root/test/parallel/test-http-client-set-timeout.js
blob: 15aae7023bf3f1ecd50757471afb9dbf0820e02c (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
'use strict';

// Test that the `'timeout'` event is emitted exactly once if the `timeout`
// option and `request.setTimeout()` are used together.

const { expectsError, mustCall } = require('../common');
const { strictEqual } = require('assert');
const { createServer, get } = require('http');

const server = createServer(() => {
  // Never respond.
});

server.listen(0, mustCall(() => {
  const req = get({
    port: server.address().port,
    timeout: 2000,
  });

  req.setTimeout(1000);

  req.on('socket', mustCall((socket) => {
    strictEqual(socket.timeout, 2000);

    socket.on('connect', mustCall(() => {
      strictEqual(socket.timeout, 1000);

      // Reschedule the timer to not wait 1 sec and make the test finish faster.
      socket.setTimeout(10);
      strictEqual(socket.timeout, 10);
    }));
  }));

  req.on('error', expectsError({
    type: Error,
    code: 'ECONNRESET',
    message: 'socket hang up'
  }));

  req.on('close', mustCall(() => {
    server.close();
  }));

  req.on('timeout', mustCall(() => {
    strictEqual(req.socket.listenerCount('timeout'), 0);
    req.destroy();
  }));
}));