node/test/parallel/test-dgram-send-address-types.js
Ruben Bridgewater 1ed3c54ecb
errors: update error name
This updates all Node.js errors by removing the `code` being part
of the `name` property. Instead, the name is just changed once on
instantiation, the stack is accessed to create the stack as expected
and then the `name` property is set back to it's original form.

PR-URL: https://github.com/nodejs/node/pull/26738
Fixes: https://github.com/nodejs/node/issues/26669
Fixes: https://github.com/nodejs/node/issues/20253
Reviewed-By: Gus Caplan <me@gus.host>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com>
2019-03-23 02:55:54 +01:00

37 lines
991 B
JavaScript

'use strict';
const common = require('../common');
const assert = require('assert');
const dgram = require('dgram');
const buf = Buffer.from('test');
const onMessage = common.mustCall((err, bytes) => {
assert.ifError(err);
assert.strictEqual(bytes, buf.length);
}, 6);
const client = dgram.createSocket('udp4').bind(0, () => {
const port = client.address().port;
// Check valid addresses
[false, '', null, 0, undefined].forEach((address) => {
client.send(buf, port, address, onMessage);
});
// Valid address: not provided
client.send(buf, port, onMessage);
// Check invalid addresses
[[], 1, true].forEach((invalidInput) => {
const expectedError = {
code: 'ERR_INVALID_ARG_TYPE',
name: 'TypeError',
message: 'The "address" argument must be one of type string or falsy. ' +
`Received type ${typeof invalidInput}`
};
assert.throws(() => client.send(buf, port, invalidInput), expectedError);
});
});
client.unref();