test: refactor the code in test-dns-ipv6
* remove the manual control for functions execution * use common.mustCall to control the functions execution automatically * use let and const instead of var * use assert.strictEqual instead assert.equal PR-URL: https://github.com/nodejs/node/pull/10219 Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com>
This commit is contained in:
parent
8b367c5ddd
commit
5e781a3883
@ -5,8 +5,6 @@ const dns = require('dns');
|
|||||||
const net = require('net');
|
const net = require('net');
|
||||||
const isIPv6 = net.isIPv6;
|
const isIPv6 = net.isIPv6;
|
||||||
|
|
||||||
let expected = 0;
|
|
||||||
let completed = 0;
|
|
||||||
let running = false;
|
let running = false;
|
||||||
const queue = [];
|
const queue = [];
|
||||||
|
|
||||||
@ -17,7 +15,7 @@ if (!common.hasIPv6) {
|
|||||||
|
|
||||||
function TEST(f) {
|
function TEST(f) {
|
||||||
function next() {
|
function next() {
|
||||||
var f = queue.shift();
|
const f = queue.shift();
|
||||||
if (f) {
|
if (f) {
|
||||||
running = true;
|
running = true;
|
||||||
console.log(f.name);
|
console.log(f.name);
|
||||||
@ -27,11 +25,9 @@ function TEST(f) {
|
|||||||
|
|
||||||
function done() {
|
function done() {
|
||||||
running = false;
|
running = false;
|
||||||
completed++;
|
|
||||||
process.nextTick(next);
|
process.nextTick(next);
|
||||||
}
|
}
|
||||||
|
|
||||||
expected++;
|
|
||||||
queue.push(f);
|
queue.push(f);
|
||||||
|
|
||||||
if (!running) {
|
if (!running) {
|
||||||
@ -44,46 +40,46 @@ function checkWrap(req) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
TEST(function test_resolve6(done) {
|
TEST(function test_resolve6(done) {
|
||||||
var req = dns.resolve6('ipv6.google.com', function(err, ips) {
|
const req = dns.resolve6('ipv6.google.com',
|
||||||
if (err) throw err;
|
common.mustCall((err, ips) => {
|
||||||
|
assert.ifError(err);
|
||||||
|
|
||||||
assert.ok(ips.length > 0);
|
assert.ok(ips.length > 0);
|
||||||
|
|
||||||
for (var i = 0; i < ips.length; i++) {
|
for (let i = 0; i < ips.length; i++)
|
||||||
assert.ok(isIPv6(ips[i]));
|
assert.ok(isIPv6(ips[i]));
|
||||||
}
|
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
TEST(function test_reverse_ipv6(done) {
|
TEST(function test_reverse_ipv6(done) {
|
||||||
var req = dns.reverse('2001:4860:4860::8888', function(err, domains) {
|
const req = dns.reverse('2001:4860:4860::8888',
|
||||||
if (err) throw err;
|
common.mustCall((err, domains) => {
|
||||||
|
assert.ifError(err);
|
||||||
|
|
||||||
assert.ok(domains.length > 0);
|
assert.ok(domains.length > 0);
|
||||||
|
|
||||||
for (var i = 0; i < domains.length; i++) {
|
for (let i = 0; i < domains.length; i++)
|
||||||
assert.ok(domains[i]);
|
assert.ok(typeof domains[i] === 'string');
|
||||||
assert.ok(typeof domains[i] === 'string');
|
|
||||||
}
|
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
TEST(function test_lookup_ipv6_explicit(done) {
|
TEST(function test_lookup_ipv6_explicit(done) {
|
||||||
var req = dns.lookup('ipv6.google.com', 6, function(err, ip, family) {
|
const req = dns.lookup('ipv6.google.com', 6,
|
||||||
if (err) throw err;
|
common.mustCall((err, ip, family) => {
|
||||||
assert.ok(net.isIPv6(ip));
|
assert.ifError(err);
|
||||||
assert.strictEqual(family, 6);
|
assert.ok(isIPv6(ip));
|
||||||
|
assert.strictEqual(family, 6);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
@ -103,24 +99,24 @@ TEST(function test_lookup_ipv6_implicit(done) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
TEST(function test_lookup_ipv6_explicit_object(done) {
|
TEST(function test_lookup_ipv6_explicit_object(done) {
|
||||||
var req = dns.lookup('ipv6.google.com', {
|
const req = dns.lookup('ipv6.google.com', {
|
||||||
family: 6
|
family: 6
|
||||||
}, function(err, ip, family) {
|
}, common.mustCall((err, ip, family) => {
|
||||||
if (err) throw err;
|
assert.ifError(err);
|
||||||
assert.ok(net.isIPv6(ip));
|
assert.ok(isIPv6(ip));
|
||||||
assert.strictEqual(family, 6);
|
assert.strictEqual(family, 6);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
TEST(function test_lookup_ipv6_hint(done) {
|
TEST(function test_lookup_ipv6_hint(done) {
|
||||||
var req = dns.lookup('www.google.com', {
|
const req = dns.lookup('www.google.com', {
|
||||||
family: 6,
|
family: 6,
|
||||||
hints: dns.V4MAPPED
|
hints: dns.V4MAPPED
|
||||||
}, function(err, ip, family) {
|
}, common.mustCall((err, ip, family) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
// FreeBSD does not support V4MAPPED
|
// FreeBSD does not support V4MAPPED
|
||||||
if (common.isFreeBSD) {
|
if (common.isFreeBSD) {
|
||||||
@ -130,41 +126,43 @@ TEST(function test_lookup_ipv6_hint(done) {
|
|||||||
assert.ok(/getaddrinfo EAI_BADFLAGS/.test(err.message));
|
assert.ok(/getaddrinfo EAI_BADFLAGS/.test(err.message));
|
||||||
done();
|
done();
|
||||||
return;
|
return;
|
||||||
} else {
|
|
||||||
throw err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert.ifError(err);
|
||||||
}
|
}
|
||||||
assert.ok(net.isIPv6(ip));
|
|
||||||
|
assert.ok(isIPv6(ip));
|
||||||
assert.strictEqual(family, 6);
|
assert.strictEqual(family, 6);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
TEST(function test_lookup_ip_ipv6(done) {
|
TEST(function test_lookup_ip_ipv6(done) {
|
||||||
var req = dns.lookup('::1', function(err, ip, family) {
|
const req = dns.lookup('::1',
|
||||||
if (err) throw err;
|
common.mustCall((err, ip, family) => {
|
||||||
assert.ok(net.isIPv6(ip));
|
assert.ifError(err);
|
||||||
assert.strictEqual(family, 6);
|
assert.ok(isIPv6(ip));
|
||||||
|
assert.strictEqual(family, 6);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
TEST(function test_lookup_all_ipv6(done) {
|
TEST(function test_lookup_all_ipv6(done) {
|
||||||
var req = dns.lookup(
|
const req = dns.lookup(
|
||||||
'www.google.com',
|
'www.google.com',
|
||||||
{all: true, family: 6},
|
{all: true, family: 6},
|
||||||
function(err, ips) {
|
common.mustCall((err, ips) => {
|
||||||
if (err) throw err;
|
assert.ifError(err);
|
||||||
assert.ok(Array.isArray(ips));
|
assert.ok(Array.isArray(ips));
|
||||||
assert.ok(ips.length > 0);
|
assert.ok(ips.length > 0);
|
||||||
|
|
||||||
ips.forEach(function(ip) {
|
ips.forEach((ip) => {
|
||||||
assert.ok(isIPv6(ip.address),
|
assert.ok(isIPv6(ip.address),
|
||||||
'Invalid IPv6: ' + ip.address.toString());
|
'Invalid IPv6: ' + ip.address.toString());
|
||||||
assert.strictEqual(ip.family, 6);
|
assert.strictEqual(ip.family, 6);
|
||||||
@ -172,24 +170,25 @@ TEST(function test_lookup_all_ipv6(done) {
|
|||||||
|
|
||||||
done();
|
done();
|
||||||
}
|
}
|
||||||
);
|
));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
TEST(function test_lookupservice_ip_ipv6(done) {
|
TEST(function test_lookupservice_ip_ipv6(done) {
|
||||||
var req = dns.lookupService('::1', 80, function(err, host, service) {
|
const req = dns.lookupService('::1', 80,
|
||||||
if (err) {
|
common.mustCall((err, host, service) => {
|
||||||
// Not skipping the test, rather checking an alternative result,
|
if (err) {
|
||||||
// i.e. that ::1 may not be configured (e.g. in /etc/hosts)
|
// Not skipping the test, rather checking an alternative result,
|
||||||
assert.strictEqual(err.code, 'ENOTFOUND');
|
// i.e. that ::1 may not be configured (e.g. in /etc/hosts)
|
||||||
return done();
|
assert.strictEqual(err.code, 'ENOTFOUND');
|
||||||
}
|
return done();
|
||||||
assert.equal(typeof host, 'string');
|
}
|
||||||
assert(host);
|
assert.strictEqual(typeof host, 'string');
|
||||||
assert(['http', 'www', '80'].includes(service));
|
assert(host);
|
||||||
done();
|
assert(['http', 'www', '80'].includes(service));
|
||||||
});
|
done();
|
||||||
|
}));
|
||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
});
|
});
|
||||||
@ -206,9 +205,3 @@ TEST(function test_lookupservice_ip_ipv6(done) {
|
|||||||
|
|
||||||
checkWrap(req);
|
checkWrap(req);
|
||||||
}); */
|
}); */
|
||||||
|
|
||||||
process.on('exit', function() {
|
|
||||||
console.log(completed + ' tests completed');
|
|
||||||
assert.equal(running, false);
|
|
||||||
assert.strictEqual(expected, completed);
|
|
||||||
});
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user