Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: fix race in test-net-server-pause-on-connect #4637

Closed
wants to merge 1 commit into from
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);
});