-
-
Notifications
You must be signed in to change notification settings - Fork 756
Expand file tree
/
Copy path401-statuscode-no-infinite-loop.js
More file actions
45 lines (36 loc) · 1.32 KB
/
401-statuscode-no-infinite-loop.js
File metadata and controls
45 lines (36 loc) · 1.32 KB
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
'use strict'
const { fetch } = require('../..')
const { createServer } = require('node:http')
const { once } = require('node:events')
const { test } = require('node:test')
const assert = require('node:assert')
const { closeServerAsPromise } = require('../utils/node-http')
test('Receiving a 401 status code should not cause infinite retry loop', async (t) => {
const server = createServer({ joinDuplicateHeaders: true }, (req, res) => {
res.statusCode = 401
res.end('Unauthorized')
}).listen(0)
t.after(closeServerAsPromise(server))
await once(server, 'listening')
const response = await fetch(`http://localhost:${server.address().port}`)
assert.strictEqual(response.status, 401)
})
test('Receiving a 401 status code should not fail for stream-backed request bodies', async (t) => {
const server = createServer({ joinDuplicateHeaders: true }, (req, res) => {
res.statusCode = 401
res.end('Unauthorized')
}).listen(0)
t.after(closeServerAsPromise(server))
await once(server, 'listening')
const response = await fetch(`http://localhost:${server.address().port}`, {
method: 'PUT',
duplex: 'half',
body: new ReadableStream({
start (controller) {
controller.enqueue(Buffer.from('hello world'))
controller.close()
}
})
})
assert.strictEqual(response.status, 401)
})