node/test/parallel/test-net-binary.js
Gibson Fahnestock 3d2aef3979 test: s/assert.equal/assert.strictEqual/
Use assert.strictEqual instead of assert.equal in tests, manually
convert types where necessary.

PR-URL: https://github.com/nodejs/node/pull/10698
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
Reviewed-By: Teddy Katz <teddy.katz@gmail.com>
2017-01-11 14:19:26 +00:00

68 lines
1.4 KiB
JavaScript

/* eslint-disable strict */
require('../common');
const assert = require('assert');
const net = require('net');
let binaryString = '';
for (let i = 255; i >= 0; i--) {
const s = `'\\${i.toString(8)}'`;
const S = eval(s);
assert.strictEqual(S.charCodeAt(0), i);
assert.strictEqual(S, String.fromCharCode(i));
binaryString += S;
}
// safe constructor
const echoServer = net.Server(function(connection) {
connection.setEncoding('latin1');
connection.on('data', function(chunk) {
connection.write(chunk, 'latin1');
});
connection.on('end', function() {
connection.end();
});
});
echoServer.listen(0);
let recv = '';
echoServer.on('listening', function() {
let j = 0;
const c = net.createConnection({
port: this.address().port
});
c.setEncoding('latin1');
c.on('data', function(chunk) {
const n = j + chunk.length;
while (j < n && j < 256) {
c.write(String.fromCharCode(j), 'latin1');
j++;
}
if (j === 256) {
c.end();
}
recv += chunk;
});
c.on('connect', function() {
c.write(binaryString, 'binary');
});
c.on('close', function() {
echoServer.close();
});
});
process.on('exit', function() {
assert.strictEqual(2 * 256, recv.length);
const a = recv.split('');
const first = a.slice(0, 256).reverse().join('');
const second = a.slice(256, 2 * 256).join('');
assert.strictEqual(first, second);
});