mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
0090c10782
PR-URL: https://github.com/nodejs/node/pull/51385 Reviewed-By: Richard Lau <rlau@redhat.com> Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Michael Dawson <midawson@redhat.com>
55 lines
1.9 KiB
JavaScript
55 lines
1.9 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const dnstools = require('../common/dns');
|
|
const dns = require('dns');
|
|
const assert = require('assert');
|
|
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);
|
|
const domain = parsed.questions[0].domain;
|
|
assert.strictEqual(domain, 'example.org');
|
|
|
|
const buf = dnstools.writeDNSPacket({
|
|
id: parsed.id,
|
|
questions: parsed.questions,
|
|
answers: { type: 'A', address: '1.2.3.4', ttl: 123, domain },
|
|
});
|
|
// 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();
|
|
resolver.setServers([`127.0.0.1:${address.port}`]);
|
|
resolverPromises.setServers([`127.0.0.1:${address.port}`]);
|
|
|
|
resolverPromises.resolveAny('example.org')
|
|
.then(common.mustNotCall())
|
|
.catch(common.expectsError({
|
|
// May return EBADRESP or ETIMEOUT
|
|
code: /^(?:EBADRESP|ETIMEOUT)$/,
|
|
syscall: 'queryAny',
|
|
hostname: 'example.org'
|
|
}));
|
|
|
|
resolver.resolveAny('example.org', common.mustCall((err) => {
|
|
assert.notStrictEqual(err.code, 'SUCCESS');
|
|
assert.strictEqual(err.syscall, 'queryAny');
|
|
assert.strictEqual(err.hostname, 'example.org');
|
|
const descriptor = Object.getOwnPropertyDescriptor(err, 'message');
|
|
// The error message should be non-enumerable.
|
|
assert.strictEqual(descriptor.enumerable, false);
|
|
server.close();
|
|
}));
|
|
}));
|