From 6efaef606af890e05deab0a892b1214f7f8421a9 Mon Sep 17 00:00:00 2001 From: Yoshiya Hinosawa Date: Tue, 18 Apr 2023 15:20:36 +0900 Subject: [PATCH] fix(ext/node): polyfill response._implicitHeader method (#18738) --- cli/tests/unit_node/http_test.ts | 29 +++++++++++++++++++++++++++++ ext/node/polyfills/http.ts | 7 ++++++- 2 files changed, 35 insertions(+), 1 deletion(-) create mode 100644 cli/tests/unit_node/http_test.ts diff --git a/cli/tests/unit_node/http_test.ts b/cli/tests/unit_node/http_test.ts new file mode 100644 index 0000000000..c32bf62f26 --- /dev/null +++ b/cli/tests/unit_node/http_test.ts @@ -0,0 +1,29 @@ +// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license. + +import http from "node:http"; +import { assertEquals } from "../../../test_util/std/testing/asserts.ts"; +import { assertSpyCalls, spy } from "../../../test_util/std/testing/mock.ts"; +import { deferred } from "../../../test_util/std/async/deferred.ts"; + +Deno.test("[node/http] ServerResponse _implicitHeader", async () => { + const d = deferred(); + const server = http.createServer((_req, res) => { + const writeHeadSpy = spy(res, "writeHead"); + // deno-lint-ignore no-explicit-any + (res as any)._implicitHeader(); + assertSpyCalls(writeHeadSpy, 1); + writeHeadSpy.restore(); + res.end("Hello World"); + }); + + server.listen(async () => { + const { port } = server.address() as { port: number }; + const res = await fetch(`http://localhost:${port}`); + assertEquals(await res.text(), "Hello World"); + server.close(() => { + d.resolve(); + }); + }); + + await d; +}); diff --git a/ext/node/polyfills/http.ts b/ext/node/polyfills/http.ts index ab5e2b438f..12d71277f0 100644 --- a/ext/node/polyfills/http.ts +++ b/ext/node/polyfills/http.ts @@ -485,7 +485,7 @@ export class ServerResponse extends NodeWritable { return this.#headers.has(name); } - writeHead(status: number, headers: Record) { + writeHead(status: number, headers: Record = {}) { this.statusCode = status; for (const k in headers) { if (Object.hasOwn(headers, k)) { @@ -540,6 +540,11 @@ export class ServerResponse extends NodeWritable { // @ts-expect-error The signature for cb is stricter than the one implemented here return super.end(chunk, encoding, cb); } + + // Undocumented API used by `npm:compression`. + _implicitHeader() { + this.writeHead(this.statusCode); + } } // TODO(@AaronO): optimize