summaryrefslogtreecommitdiffstats
path: root/test/fetch/fetch-timeouts.js
blob: b659aaa08d6ecab4a02236335ae71fb004be1a5c (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
52
53
54
55
56
'use strict'

const { test } = require('tap')

const { fetch, Agent } = require('../..')
const timers = require('../../lib/timers')
const { createServer } = require('http')
const FakeTimers = require('@sinonjs/fake-timers')

test('Fetch very long request, timeout overridden so no error', (t) => {
  const minutes = 6
  const msToDelay = 1000 * 60 * minutes

  t.setTimeout(undefined)
  t.plan(1)

  const clock = FakeTimers.install()
  t.teardown(clock.uninstall.bind(clock))

  const orgTimers = { ...timers }
  Object.assign(timers, { setTimeout, clearTimeout })
  t.teardown(() => {
    Object.assign(timers, orgTimers)
  })

  const server = createServer((req, res) => {
    setTimeout(() => {
      res.end('hello')
    }, msToDelay)
    clock.tick(msToDelay + 1)
  })
  t.teardown(server.close.bind(server))

  server.listen(0, () => {
    fetch(`http://localhost:${server.address().port}`, {
      path: '/',
      method: 'GET',
      dispatcher: new Agent({
        headersTimeout: 0,
        connectTimeout: 0,
        bodyTimeout: 0
      })
    })
      .then((response) => response.text())
      .then((response) => {
        t.equal('hello', response)
        t.end()
      })
      .catch((err) => {
        // This should not happen, a timeout error should not occur
        t.error(err)
      })

    clock.tick(msToDelay - 1)
  })
})