summaryrefslogtreecommitdiff
path: root/test/internet/test-dns.js
diff options
context:
space:
mode:
authorcjihrig <cjihrig@gmail.com>2018-06-11 14:56:33 -0400
committercjihrig <cjihrig@gmail.com>2018-06-20 13:35:27 -0400
commit7486c4d71060e2ae3e754cf01e8fb02696eacd13 (patch)
tree8b48c47271d474800f1222f729e93f477f3fd395 /test/internet/test-dns.js
parentfea3595c2f92beb0d31feb93da1c972cc30e6fec (diff)
downloadandroid-node-v8-7486c4d71060e2ae3e754cf01e8fb02696eacd13.tar.gz
android-node-v8-7486c4d71060e2ae3e754cf01e8fb02696eacd13.tar.bz2
android-node-v8-7486c4d71060e2ae3e754cf01e8fb02696eacd13.zip
dns: add promisified dns module
PR-URL: https://github.com/nodejs/node/pull/21264 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Diffstat (limited to 'test/internet/test-dns.js')
-rw-r--r--test/internet/test-dns.js258
1 files changed, 190 insertions, 68 deletions
diff --git a/test/internet/test-dns.js b/test/internet/test-dns.js
index 56fa370fce..593d621e82 100644
--- a/test/internet/test-dns.js
+++ b/test/internet/test-dns.js
@@ -28,6 +28,7 @@ const net = require('net');
const isIPv4 = net.isIPv4;
const isIPv6 = net.isIPv6;
const util = require('util');
+const dnsPromises = dns.promises;
common.crashOnUnhandledRejection();
@@ -68,17 +69,18 @@ function checkWrap(req) {
TEST(function test_reverse_bogus(done) {
+ dnsPromises.reverse('bogus ip')
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'EINVAL' }));
+
assert.throws(() => {
dns.reverse('bogus ip', common.mustNotCall());
}, /^Error: getHostByAddr EINVAL bogus ip$/);
done();
});
-TEST(function test_resolve4_ttl(done) {
- const req = dns.resolve4(addresses.INET4_HOST, {
- ttl: true
- }, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolve4_ttl(done) {
+ function validateResult(result) {
assert.ok(result.length > 0);
for (let i = 0; i < result.length; i++) {
@@ -90,18 +92,25 @@ TEST(function test_resolve4_ttl(done) {
assert.ok(item.ttl > 0);
assert.ok(isIPv4(item.address));
}
+ }
+
+ validateResult(await dnsPromises.resolve4(addresses.INET4_HOST, {
+ ttl: true
+ }));
+ const req = dns.resolve4(addresses.INET4_HOST, {
+ ttl: true
+ }, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
checkWrap(req);
});
-TEST(function test_resolve6_ttl(done) {
- const req = dns.resolve6(addresses.INET6_HOST, {
- ttl: true
- }, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolve6_ttl(done) {
+ function validateResult(result) {
assert.ok(result.length > 0);
for (let i = 0; i < result.length; i++) {
@@ -113,29 +122,42 @@ TEST(function test_resolve6_ttl(done) {
assert.ok(item.ttl > 0);
assert.ok(isIPv6(item.address));
}
+ }
+
+ validateResult(await dnsPromises.resolve6(addresses.INET6_HOST, {
+ ttl: true
+ }));
+ const req = dns.resolve6(addresses.INET6_HOST, {
+ ttl: true
+ }, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
checkWrap(req);
});
-TEST(function test_resolveMx(done) {
- const req = dns.resolveMx(addresses.MX_HOST, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolveMx(done) {
+ function validateResult(result) {
assert.ok(result.length > 0);
for (let i = 0; i < result.length; i++) {
const item = result[i];
assert.ok(item);
assert.strictEqual(typeof item, 'object');
-
assert.ok(item.exchange);
assert.strictEqual(typeof item.exchange, 'string');
-
assert.strictEqual(typeof item.priority, 'number');
}
+ }
+ validateResult(await dnsPromises.resolveMx(addresses.MX_HOST));
+
+ const req = dns.resolveMx(addresses.MX_HOST, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
@@ -143,6 +165,10 @@ TEST(function test_resolveMx(done) {
});
TEST(function test_resolveMx_failure(done) {
+ dnsPromises.resolveMx(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveMx(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -155,17 +181,23 @@ TEST(function test_resolveMx_failure(done) {
checkWrap(req);
});
-TEST(function test_resolveNs(done) {
- const req = dns.resolveNs(addresses.NS_HOST, function(err, names) {
- assert.ifError(err);
- assert.ok(names.length > 0);
+TEST(async function test_resolveNs(done) {
+ function validateResult(result) {
+ assert.ok(result.length > 0);
- for (let i = 0; i < names.length; i++) {
- const name = names[i];
- assert.ok(name);
- assert.strictEqual(typeof name, 'string');
+ for (let i = 0; i < result.length; i++) {
+ const item = result[i];
+
+ assert.ok(item);
+ assert.strictEqual(typeof item, 'string');
}
+ }
+ validateResult(await dnsPromises.resolveNs(addresses.NS_HOST));
+
+ const req = dns.resolveNs(addresses.NS_HOST, function(err, names) {
+ assert.ifError(err);
+ validateResult(names);
done();
});
@@ -173,6 +205,10 @@ TEST(function test_resolveNs(done) {
});
TEST(function test_resolveNs_failure(done) {
+ dnsPromises.resolveNs(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveNs(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -185,9 +221,8 @@ TEST(function test_resolveNs_failure(done) {
checkWrap(req);
});
-TEST(function test_resolveSrv(done) {
- const req = dns.resolveSrv(addresses.SRV_HOST, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolveSrv(done) {
+ function validateResult(result) {
assert.ok(result.length > 0);
for (let i = 0; i < result.length; i++) {
@@ -202,7 +237,13 @@ TEST(function test_resolveSrv(done) {
assert.strictEqual(typeof item.priority, 'number');
assert.strictEqual(typeof item.weight, 'number');
}
+ }
+ validateResult(await dnsPromises.resolveSrv(addresses.SRV_HOST));
+
+ const req = dns.resolveSrv(addresses.SRV_HOST, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
@@ -210,6 +251,10 @@ TEST(function test_resolveSrv(done) {
});
TEST(function test_resolveSrv_failure(done) {
+ dnsPromises.resolveSrv(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveSrv(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -222,9 +267,8 @@ TEST(function test_resolveSrv_failure(done) {
checkWrap(req);
});
-TEST(function test_resolvePtr(done) {
- const req = dns.resolvePtr(addresses.PTR_HOST, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolvePtr(done) {
+ function validateResult(result) {
assert.ok(result.length > 0);
for (let i = 0; i < result.length; i++) {
@@ -232,7 +276,13 @@ TEST(function test_resolvePtr(done) {
assert.ok(item);
assert.strictEqual(typeof item, 'string');
}
+ }
+
+ validateResult(await dnsPromises.resolvePtr(addresses.PTR_HOST));
+ const req = dns.resolvePtr(addresses.PTR_HOST, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
@@ -240,6 +290,10 @@ TEST(function test_resolvePtr(done) {
});
TEST(function test_resolvePtr_failure(done) {
+ dnsPromises.resolvePtr(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolvePtr(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -252,16 +306,14 @@ TEST(function test_resolvePtr_failure(done) {
checkWrap(req);
});
-TEST(function test_resolveNaptr(done) {
- const req = dns.resolveNaptr(addresses.NAPTR_HOST, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolveNaptr(done) {
+ function validateResult(result) {
assert.ok(result.length > 0);
for (let i = 0; i < result.length; i++) {
const item = result[i];
assert.ok(item);
assert.strictEqual(typeof item, 'object');
-
assert.strictEqual(typeof item.flags, 'string');
assert.strictEqual(typeof item.service, 'string');
assert.strictEqual(typeof item.regexp, 'string');
@@ -269,7 +321,13 @@ TEST(function test_resolveNaptr(done) {
assert.strictEqual(typeof item.order, 'number');
assert.strictEqual(typeof item.preference, 'number');
}
+ }
+ validateResult(await dnsPromises.resolveNaptr(addresses.NAPTR_HOST));
+
+ const req = dns.resolveNaptr(addresses.NAPTR_HOST, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
@@ -277,6 +335,10 @@ TEST(function test_resolveNaptr(done) {
});
TEST(function test_resolveNaptr_failure(done) {
+ dnsPromises.resolveNaptr(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveNaptr(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -289,33 +351,31 @@ TEST(function test_resolveNaptr_failure(done) {
checkWrap(req);
});
-TEST(function test_resolveSoa(done) {
- const req = dns.resolveSoa(addresses.SOA_HOST, function(err, result) {
- assert.ifError(err);
+TEST(async function test_resolveSoa(done) {
+ function validateResult(result) {
assert.ok(result);
assert.strictEqual(typeof result, 'object');
-
assert.strictEqual(typeof result.nsname, 'string');
assert.ok(result.nsname.length > 0);
-
assert.strictEqual(typeof result.hostmaster, 'string');
assert.ok(result.hostmaster.length > 0);
-
assert.strictEqual(typeof result.serial, 'number');
assert.ok((result.serial > 0) && (result.serial < 4294967295));
-
assert.strictEqual(typeof result.refresh, 'number');
assert.ok((result.refresh > 0) && (result.refresh < 2147483647));
-
assert.strictEqual(typeof result.retry, 'number');
assert.ok((result.retry > 0) && (result.retry < 2147483647));
-
assert.strictEqual(typeof result.expire, 'number');
assert.ok((result.expire > 0) && (result.expire < 2147483647));
-
assert.strictEqual(typeof result.minttl, 'number');
assert.ok((result.minttl >= 0) && (result.minttl < 2147483647));
+ }
+ validateResult(await dnsPromises.resolveSoa(addresses.SOA_HOST));
+
+ const req = dns.resolveSoa(addresses.SOA_HOST, function(err, result) {
+ assert.ifError(err);
+ validateResult(result);
done();
});
@@ -323,6 +383,10 @@ TEST(function test_resolveSoa(done) {
});
TEST(function test_resolveSoa_failure(done) {
+ dnsPromises.resolveSoa(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveSoa(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -335,17 +399,22 @@ TEST(function test_resolveSoa_failure(done) {
checkWrap(req);
});
-TEST(function test_resolveCname(done) {
- const req = dns.resolveCname(addresses.CNAME_HOST, function(err, names) {
- assert.ifError(err);
- assert.ok(names.length > 0);
+TEST(async function test_resolveCname(done) {
+ function validateResult(result) {
+ assert.ok(result.length > 0);
- for (let i = 0; i < names.length; i++) {
- const name = names[i];
+ for (let i = 0; i < result.length; i++) {
+ const name = result[i];
assert.ok(name);
assert.strictEqual(typeof name, 'string');
}
+ }
+
+ validateResult(await dnsPromises.resolveCname(addresses.CNAME_HOST));
+ const req = dns.resolveCname(addresses.CNAME_HOST, function(err, names) {
+ assert.ifError(err);
+ validateResult(names);
done();
});
@@ -353,6 +422,10 @@ TEST(function test_resolveCname(done) {
});
TEST(function test_resolveCname_failure(done) {
+ dnsPromises.resolveCname(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveCname(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -366,12 +439,18 @@ TEST(function test_resolveCname_failure(done) {
});
-TEST(function test_resolveTxt(done) {
+TEST(async function test_resolveTxt(done) {
+ function validateResult(result) {
+ assert.ok(Array.isArray(result[0]));
+ assert.strictEqual(result.length, 1);
+ assert(result[0][0].startsWith('v=spf1'));
+ }
+
+ validateResult(await dnsPromises.resolveTxt(addresses.TXT_HOST));
+
const req = dns.resolveTxt(addresses.TXT_HOST, function(err, records) {
assert.ifError(err);
- assert.strictEqual(records.length, 1);
- assert.ok(util.isArray(records[0]));
- assert(records[0][0].startsWith('v=spf1'));
+ validateResult(records);
done();
});
@@ -379,6 +458,10 @@ TEST(function test_resolveTxt(done) {
});
TEST(function test_resolveTxt_failure(done) {
+ dnsPromises.resolveTxt(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: 'ENOTFOUND' }));
+
const req = dns.resolveTxt(addresses.INVALID_HOST, function(err, result) {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, 'ENOTFOUND');
@@ -393,6 +476,10 @@ TEST(function test_resolveTxt_failure(done) {
TEST(function test_lookup_failure(done) {
+ dnsPromises.lookup(addresses.INVALID_HOST, 4)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ errno: dns.NOTFOUND }));
+
const req = dns.lookup(addresses.INVALID_HOST, 4, (err, ip, family) => {
assert.ok(err instanceof Error);
assert.strictEqual(err.errno, dns.NOTFOUND);
@@ -407,17 +494,23 @@ TEST(function test_lookup_failure(done) {
});
-TEST(function test_lookup_ip_all(done) {
+TEST(async function test_lookup_ip_all(done) {
+ function validateResult(result) {
+ assert.ok(Array.isArray(result));
+ assert.ok(result.length > 0);
+ assert.strictEqual(result[0].address, '127.0.0.1');
+ assert.strictEqual(result[0].family, 4);
+ }
+
+ validateResult(await dnsPromises.lookup('127.0.0.1', { all: true }));
+
const req = dns.lookup(
'127.0.0.1',
{ all: true },
function(err, ips, family) {
assert.ifError(err);
- assert.ok(Array.isArray(ips));
- assert.ok(ips.length > 0);
- assert.strictEqual(ips[0].address, '127.0.0.1');
- assert.strictEqual(ips[0].family, 4);
-
+ assert.strictEqual(family, undefined);
+ validateResult(ips);
done();
}
);
@@ -452,7 +545,9 @@ TEST(function test_lookup_ip_promise(done) {
});
-TEST(function test_lookup_null_all(done) {
+TEST(async function test_lookup_null_all(done) {
+ assert.deepStrictEqual(await dnsPromises.lookup(null, { all: true }), []);
+
const req = dns.lookup(null, { all: true }, function(err, ips, family) {
assert.ifError(err);
assert.ok(Array.isArray(ips));
@@ -465,15 +560,12 @@ TEST(function test_lookup_null_all(done) {
});
-TEST(function test_lookup_all_mixed(done) {
- const req = dns.lookup(addresses.INET_HOST, {
- all: true
- }, function(err, ips) {
- assert.ifError(err);
- assert.ok(Array.isArray(ips));
- assert.ok(ips.length > 0);
+TEST(async function test_lookup_all_mixed(done) {
+ function validateResult(result) {
+ assert.ok(Array.isArray(result));
+ assert.ok(result.length > 0);
- ips.forEach(function(ip) {
+ result.forEach(function(ip) {
if (isIPv4(ip.address))
assert.strictEqual(ip.family, 4);
else if (isIPv6(ip.address))
@@ -481,7 +573,15 @@ TEST(function test_lookup_all_mixed(done) {
else
assert.fail('unexpected IP address');
});
+ }
+
+ validateResult(await dnsPromises.lookup(addresses.INET_HOST, { all: true }));
+ const req = dns.lookup(addresses.INET_HOST, {
+ all: true
+ }, function(err, ips) {
+ assert.ifError(err);
+ validateResult(ips);
done();
});
@@ -490,6 +590,10 @@ TEST(function test_lookup_all_mixed(done) {
TEST(function test_lookupservice_invalid(done) {
+ dnsPromises.lookupService('1.2.3.4', 80)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({ code: 'ENOTFOUND' }));
+
const req = dns.lookupService('1.2.3.4', 80, function(err, host, service) {
assert(err instanceof Error);
assert.strictEqual(err.code, 'ENOTFOUND');
@@ -503,6 +607,13 @@ TEST(function test_lookupservice_invalid(done) {
TEST(function test_reverse_failure(done) {
+ dnsPromises.reverse('203.0.113.0')
+ .then(common.mustNotCall())
+ .catch(common.expectsError({
+ code: 'ENOTFOUND',
+ hostname: '203.0.113.0'
+ }));
+
// 203.0.113.0/24 are addresses reserved for (RFC) documentation use only
const req = dns.reverse('203.0.113.0', function(err) {
assert(err instanceof Error);
@@ -518,6 +629,13 @@ TEST(function test_reverse_failure(done) {
TEST(function test_lookup_failure(done) {
+ dnsPromises.lookup(addresses.INVALID_HOST)
+ .then(common.mustNotCall())
+ .catch(common.expectsError({
+ code: 'ENOTFOUND',
+ hostname: addresses.INVALID_HOST
+ }));
+
const req = dns.lookup(addresses.INVALID_HOST, (err) => {
assert(err instanceof Error);
assert.strictEqual(err.code, 'ENOTFOUND'); // Silly error code...
@@ -584,3 +702,7 @@ dns.lookup(addresses.INET6_HOST, 6, common.mustCall());
dns.lookup(addresses.INET_HOST, {}, common.mustCall());
dns.lookupService('0.0.0.0', '0', common.mustCall());
dns.lookupService('0.0.0.0', 0, common.mustCall());
+(async function() {
+ await dnsPromises.lookup(addresses.INET6_HOST, 6);
+ await dnsPromises.lookup(addresses.INET_HOST, {});
+})();