mirror of
https://github.com/nodejs/node.git
synced 2025-05-05 10:27:05 +00:00

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>
37 lines
991 B
JavaScript
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();
|