Skip to content

Commit 1216ba0

Browse files
authored
perf(headers): a single set-cookie (#2903)
1 parent b4ebda2 commit 1216ba0

File tree

3 files changed

+19
-3
lines changed

3 files changed

+19
-3
lines changed

benchmarks/fetch/headers-length32.mjs

+1-1
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ const headers = new Headers(
1919
'Width',
2020
'Accept-CH',
2121
'Via',
22-
'Refresh',
22+
'Set-Cookie',
2323
'Server',
2424
'Sec-Fetch-Dest',
2525
'Sec-CH-UA-Model',

lib/web/fetch/headers.js

+1-1
Original file line numberDiff line numberDiff line change
@@ -536,7 +536,7 @@ class Headers {
536536
const cookies = this[kHeadersList].cookies
537537

538538
// fast-path
539-
if (cookies === null) {
539+
if (cookies === null || cookies.length === 1) {
540540
// Note: The non-null assertion of value has already been done by `HeadersList#toSortedArray`
541541
return (this[kHeadersList][kHeadersSortedMap] = names)
542542
}

test/fetch/headers.js

+17-1
Original file line numberDiff line numberDiff line change
@@ -694,7 +694,7 @@ test('Headers.prototype.getSetCookie', async (t) => {
694694
})
695695

696696
// https://github.com/nodejs/undici/issues/1935
697-
await t.test('When Headers are cloned, so are the cookies', async (t) => {
697+
await t.test('When Headers are cloned, so are the cookies (single entry)', async (t) => {
698698
const server = createServer((req, res) => {
699699
res.setHeader('Set-Cookie', 'test=onetwo')
700700
res.end('Hello World!')
@@ -709,6 +709,22 @@ test('Headers.prototype.getSetCookie', async (t) => {
709709
assert.deepStrictEqual(res.headers.getSetCookie(), ['test=onetwo'])
710710
assert.ok('set-cookie' in entries)
711711
})
712+
713+
await t.test('When Headers are cloned, so are the cookies (multiple entries)', async (t) => {
714+
const server = createServer((req, res) => {
715+
res.setHeader('Set-Cookie', ['test=onetwo', 'test=onetwothree'])
716+
res.end('Hello World!')
717+
}).listen(0)
718+
719+
await once(server, 'listening')
720+
t.after(closeServerAsPromise(server))
721+
722+
const res = await fetch(`http://localhost:${server.address().port}`)
723+
const entries = Object.fromEntries(res.headers.entries())
724+
725+
assert.deepStrictEqual(res.headers.getSetCookie(), ['test=onetwo', 'test=onetwothree'])
726+
assert.ok('set-cookie' in entries)
727+
})
712728
})
713729

714730
test('When the value is updated, update the cache', (t) => {

0 commit comments

Comments
 (0)