diff --git a/c-ares-fixes.patch b/c-ares-fixes.patch new file mode 100644 index 0000000..b593c52 --- /dev/null +++ b/c-ares-fixes.patch @@ -0,0 +1,46 @@ +Index: node-v20.10.0/test/parallel/test-dns-resolveany-bad-ancount.js +=================================================================== +--- node-v20.10.0.orig/test/parallel/test-dns-resolveany-bad-ancount.js ++++ node-v20.10.0/test/parallel/test-dns-resolveany-bad-ancount.js +@@ -7,6 +7,8 @@ const dgram = require('dgram'); + const dnsPromises = dns.promises; + + const server = dgram.createSocket('udp4'); ++const resolver = new dns.Resolver({ timeout: 100, tries: 1 }); ++const resolverPromises = new dnsPromises.Resolver({ timeout: 100, tries: 1 }); + + server.on('message', common.mustCall((msg, { address, port }) => { + const parsed = dnstools.parseDNSPacket(msg); +@@ -18,16 +20,20 @@ server.on('message', common.mustCall((ms + questions: parsed.questions, + answers: { type: 'A', address: '1.2.3.4', ttl: 123, domain }, + }); +- // Overwrite the # of answers with 2, which is incorrect. ++ // Overwrite the # of answers with 2, which is incorrect. The response is ++ // discarded in c-ares >= 1.21.0. This is the reason why a small timeout is ++ // used in the `Resolver` constructor. See ++ // https://github.com/nodejs/node/pull/50743#issue-1994909204 + buf.writeUInt16LE(2, 6); + server.send(buf, port, address); + }, 2)); + + server.bind(0, common.mustCall(async () => { + const address = server.address(); +- dns.setServers([`127.0.0.1:${address.port}`]); ++ resolver.setServers([`127.0.0.1:${address.port}`]); ++ resolverPromises.setServers([`127.0.0.1:${address.port}`]); + +- dnsPromises.resolveAny('example.org') ++ resolverPromises.resolveAny('example.org') + .then(common.mustNotCall()) + .catch(common.expectsError({ + code: 'EBADRESP', +@@ -35,7 +41,7 @@ server.bind(0, common.mustCall(async () + hostname: 'example.org' + })); + +- dns.resolveAny('example.org', common.mustCall((err) => { ++ resolver.resolveAny('example.org', common.mustCall((err) => { + assert.strictEqual(err.code, 'EBADRESP'); + assert.strictEqual(err.syscall, 'queryAny'); + assert.strictEqual(err.hostname, 'example.org'); diff --git a/nodejs20.changes b/nodejs20.changes index 1344dc0..6404c70 100644 --- a/nodejs20.changes +++ b/nodejs20.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Tue Jan 2 16:14:58 UTC 2024 - Adam Majer + +- c-ares-fixes.patch: fixes unit tests for new c-ares + ------------------------------------------------------------------- Thu Nov 23 08:02:58 UTC 2023 - Adam Majer - 20.10.0 diff --git a/nodejs20.spec b/nodejs20.spec index c3d272e..da6834a 100644 --- a/nodejs20.spec +++ b/nodejs20.spec @@ -177,6 +177,7 @@ Patch200: versioned.patch Patch305: qemu_timeouts_arches.patch Patch308: node-gyp-config.patch Patch309: gcc13.patch +Patch311: c-ares-fixes.patch BuildRequires: pkg-config BuildRequires: fdupes @@ -681,6 +682,7 @@ popd %if %{node_version_number} >= 19 %patch308 -p1 +%else %endif %endif @@ -695,7 +697,9 @@ popd %patch13 -p1 %patch100 -p1 %patch101 -p1 +%if 0%{?suse_version} >= 1500 || 0%{?suse_version} == 0 %patch102 -p1 +%endif # Add check_output to configure script (not part of Python 2.6 in SLE11). %if 0%{?suse_version} == 1110 %endif @@ -710,6 +714,7 @@ popd %patch305 -p1 %patch309 -p1 +%patch311 -p1 %if %{node_version_number} == 12 # minimist security update - patch50