mirror of
https://github.com/nodejs/node.git
synced 2025-05-15 16:01:52 +00:00

Logic errors that do not depend on stream state should throw instead of invoke callback and emit error. PR-URL: https://github.com/nodejs/node/pull/31831 Refs: https://github.com/nodejs/node/pull/31818 Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com>
39 lines
903 B
JavaScript
39 lines
903 B
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const net = require('net');
|
|
const assert = require('assert');
|
|
const socket = net.Stream({ highWaterMark: 0 });
|
|
|
|
// Make sure that anything besides a buffer or a string throws.
|
|
socket.on('error', common.mustNotCall());
|
|
assert.throws(() => {
|
|
socket.write(null);
|
|
}, {
|
|
code: 'ERR_STREAM_NULL_VALUES',
|
|
name: 'TypeError',
|
|
message: 'May not write null values to stream'
|
|
});
|
|
|
|
[
|
|
true,
|
|
false,
|
|
undefined,
|
|
1,
|
|
1.0,
|
|
+Infinity,
|
|
-Infinity,
|
|
[],
|
|
{}
|
|
].forEach((value) => {
|
|
// We need to check the callback since 'error' will only
|
|
// be emitted once per instance.
|
|
assert.throws(() => {
|
|
socket.write(value);
|
|
}, {
|
|
code: 'ERR_INVALID_ARG_TYPE',
|
|
name: 'TypeError',
|
|
message: 'The "chunk" argument must be of type string or an instance of ' +
|
|
`Buffer or Uint8Array.${common.invalidArgTypeHelper(value)}`
|
|
});
|
|
});
|