summaryrefslogtreecommitdiff
path: root/tests/unit_node/http_test.ts
diff options
context:
space:
mode:
authorLuca Casonato <hello@lcas.dev>2024-06-11 12:39:44 +0200
committerGitHub <noreply@github.com>2024-06-11 13:39:44 +0300
commit3d41b486da7dcba49c8a18b45425e356c329d986 (patch)
tree3e82f880b7a4a8ca1b8e0cede820073931033fbd /tests/unit_node/http_test.ts
parentd74be0842a32e4f08551be8371447254254e7ab4 (diff)
fix(ext/node): ServerResponse header array handling (#24149)
Previously res.setHeader("foo", ["bar", "baz"]) added a single header with a value of `bar,baz`. Really this should add two separate headers. This is visible in `set-cookie` for example.
Diffstat (limited to 'tests/unit_node/http_test.ts')
-rw-r--r--tests/unit_node/http_test.ts31
1 files changed, 29 insertions, 2 deletions
diff --git a/tests/unit_node/http_test.ts b/tests/unit_node/http_test.ts
index 9cb409c39..2b2644272 100644
--- a/tests/unit_node/http_test.ts
+++ b/tests/unit_node/http_test.ts
@@ -182,6 +182,33 @@ Deno.test("[node/http] server can respond with 101, 204, 205, 304 status", async
}
});
+Deno.test("[node/http] multiple set-cookie headers", async () => {
+ const { promise, resolve } = Promise.withResolvers<void>();
+
+ const server = http.createServer((_req, res) => {
+ res.setHeader("Set-Cookie", ["foo=bar", "bar=foo"]);
+ assertEquals(res.getHeader("Set-Cookie"), ["foo=bar", "bar=foo"]);
+ res.end();
+ });
+
+ server.listen(async () => {
+ const res = await fetch(
+ // deno-lint-ignore no-explicit-any
+ `http://127.0.0.1:${(server.address() as any).port}/`,
+ );
+ assert(res.ok);
+
+ const setCookieHeaders = res.headers.getSetCookie();
+ assertEquals(setCookieHeaders, ["foo=bar", "bar=foo"]);
+
+ await res.body!.cancel();
+
+ server.close(() => resolve());
+ });
+
+ await promise;
+});
+
Deno.test("[node/http] IncomingRequest socket has remoteAddress + remotePort", async () => {
const { promise, resolve } = Promise.withResolvers<void>();
@@ -1000,8 +1027,8 @@ Deno.test("[node/http] ServerResponse getHeaders", () => {
const res = new http.ServerResponse(req);
res.setHeader("foo", "bar");
res.setHeader("bar", "baz");
- assertEquals(res.getHeaderNames(), ["bar", "foo"]);
- assertEquals(res.getHeaders(), { "bar": "baz", "foo": "bar" });
+ assertEquals(res.getHeaderNames(), ["foo", "bar"]);
+ assertEquals(res.getHeaders(), { "foo": "bar", "bar": "baz" });
});
Deno.test("[node/http] ServerResponse default status code 200", () => {