test: refactor test-dgram-address.js
- separate the IPv4 and IPv6 tests using block scopes - use common.mustCall() and arrow functions for callbacks - add coverage for case where address() throws PR-URL: https://github.com/nodejs/node/pull/11271 Reviewed-By: James M Snell <jasnell@gmail.com>
This commit is contained in:
parent
fd18b656a3
commit
3a1e67dcdc
@ -3,45 +3,58 @@ const common = require('../common');
|
|||||||
const assert = require('assert');
|
const assert = require('assert');
|
||||||
const dgram = require('dgram');
|
const dgram = require('dgram');
|
||||||
|
|
||||||
// IPv4 Test
|
{
|
||||||
const socket_ipv4 = dgram.createSocket('udp4');
|
// IPv4 Test
|
||||||
const family_ipv4 = 'IPv4';
|
const socket = dgram.createSocket('udp4');
|
||||||
|
|
||||||
socket_ipv4.on('listening', function() {
|
socket.on('listening', common.mustCall(() => {
|
||||||
const address_ipv4 = socket_ipv4.address();
|
const address = socket.address();
|
||||||
assert.strictEqual(address_ipv4.address, common.localhostIPv4);
|
|
||||||
assert.strictEqual(typeof address_ipv4.port, 'number');
|
|
||||||
assert.ok(isFinite(address_ipv4.port));
|
|
||||||
assert.ok(address_ipv4.port > 0);
|
|
||||||
assert.strictEqual(address_ipv4.family, family_ipv4);
|
|
||||||
socket_ipv4.close();
|
|
||||||
});
|
|
||||||
|
|
||||||
socket_ipv4.on('error', function(e) {
|
assert.strictEqual(address.address, common.localhostIPv4);
|
||||||
console.log('Error on udp4 socket. ' + e.toString());
|
assert.strictEqual(typeof address.port, 'number');
|
||||||
socket_ipv4.close();
|
assert.ok(isFinite(address.port));
|
||||||
});
|
assert.ok(address.port > 0);
|
||||||
|
assert.strictEqual(address.family, 'IPv4');
|
||||||
|
socket.close();
|
||||||
|
}));
|
||||||
|
|
||||||
socket_ipv4.bind(0, common.localhostIPv4);
|
socket.on('error', (err) => {
|
||||||
|
socket.close();
|
||||||
|
common.fail(`Unexpected error on udp4 socket. ${err.toString()}`);
|
||||||
|
});
|
||||||
|
|
||||||
// IPv6 Test
|
socket.bind(0, common.localhostIPv4);
|
||||||
const localhost_ipv6 = '::1';
|
}
|
||||||
const socket_ipv6 = dgram.createSocket('udp6');
|
|
||||||
const family_ipv6 = 'IPv6';
|
|
||||||
|
|
||||||
socket_ipv6.on('listening', function() {
|
{
|
||||||
const address_ipv6 = socket_ipv6.address();
|
// IPv6 Test
|
||||||
assert.strictEqual(address_ipv6.address, localhost_ipv6);
|
const socket = dgram.createSocket('udp6');
|
||||||
assert.strictEqual(typeof address_ipv6.port, 'number');
|
const localhost = '::1';
|
||||||
assert.ok(isFinite(address_ipv6.port));
|
|
||||||
assert.ok(address_ipv6.port > 0);
|
|
||||||
assert.strictEqual(address_ipv6.family, family_ipv6);
|
|
||||||
socket_ipv6.close();
|
|
||||||
});
|
|
||||||
|
|
||||||
socket_ipv6.on('error', function(e) {
|
socket.on('listening', common.mustCall(() => {
|
||||||
console.log('Error on udp6 socket. ' + e.toString());
|
const address = socket.address();
|
||||||
socket_ipv6.close();
|
|
||||||
});
|
|
||||||
|
|
||||||
socket_ipv6.bind(0, localhost_ipv6);
|
assert.strictEqual(address.address, localhost);
|
||||||
|
assert.strictEqual(typeof address.port, 'number');
|
||||||
|
assert.ok(isFinite(address.port));
|
||||||
|
assert.ok(address.port > 0);
|
||||||
|
assert.strictEqual(address.family, 'IPv6');
|
||||||
|
socket.close();
|
||||||
|
}));
|
||||||
|
|
||||||
|
socket.on('error', (err) => {
|
||||||
|
socket.close();
|
||||||
|
common.fail(`Unexpected error on udp6 socket. ${err.toString()}`);
|
||||||
|
});
|
||||||
|
|
||||||
|
socket.bind(0, localhost);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
// Verify that address() throws if the socket is not bound.
|
||||||
|
const socket = dgram.createSocket('udp4');
|
||||||
|
|
||||||
|
assert.throws(() => {
|
||||||
|
socket.address();
|
||||||
|
}, /^Error: getsockname EINVAL$/);
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user