Skip to content
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
53 changes: 26 additions & 27 deletions test/parallel/test-net-server-pause-on-connect.js
Original file line number Diff line number Diff line change
@@ -1,52 +1,51 @@
'use strict';
var common = require('../common');
var assert = require('assert');
var net = require('net');
var msg = 'test';
const common = require('../common');
const assert = require('assert');
const net = require('net');
const msg = 'test';
var stopped = true;
var server1 = net.createServer({pauseOnConnect: true}, function(socket) {
var server1Sock;


const server1ConnHandler = function(socket) {
socket.on('data', function(data) {
if (stopped) {
assert(false, 'data event should not have happened yet');
common.fail('data event should not have happened yet');
}

assert.equal(data.toString(), msg, 'invalid data received');
socket.end();
server1.close();
});

setTimeout(function() {
// After 50(ish) ms, the other socket should have already read the data.
assert.equal(read, true);
assert.equal(socket.bytesRead, 0, 'no data should have been read yet');
server1Sock = socket;
};

socket.resume();
stopped = false;
}, common.platformTimeout(50));
});
const server1 = net.createServer({pauseOnConnect: true}, server1ConnHandler);

// read is a timing check, as server1's timer should fire after server2's
// connection receives the data. Note that this could be race-y.
var read = false;
var server2 = net.createServer({pauseOnConnect: false}, function(socket) {
const server2ConnHandler = function(socket) {
socket.on('data', function(data) {
read = true;

assert.equal(data.toString(), msg, 'invalid data received');
socket.end();
server2.close();

assert.equal(server1Sock.bytesRead, 0, 'no data should have been read yet');
server1Sock.resume();
stopped = false;
});
});
};

server1.listen(common.PORT, function() {
net.createConnection({port: common.PORT}).write(msg);
});
const server2 = net.createServer({pauseOnConnect: false}, server2ConnHandler);

server2.listen(common.PORT + 1, function() {
net.createConnection({port: common.PORT + 1}).write(msg);
server1.listen(common.PORT, function() {
const clientHandler = common.mustCall(function() {
server2.listen(common.PORT + 1, function() {
net.createConnection({port: common.PORT + 1}).write(msg);
});
});
net.createConnection({port: common.PORT}).write(msg, clientHandler);
});

process.on('exit', function() {
assert.equal(stopped, false);
assert.equal(read, true);
});