Browse Source

test: more test coverage for maxConnections

If the server is not accepting connections because maxConnections
is exceeded, the server should start accepting connections again
when a connection closes.

PR-URL: https://github.com/nodejs/io.js/pull/1855
Reviewed-By: Brendan Ashworth <brendan.ashworth@me.com>
v2.3.1-release
Rich Trott 10 years ago
committed by Brendan Ashworth
parent
commit
bd99e8de8e
  1. 85
      test/parallel/test-net-server-max-connections-close-makes-more-available.js
  2. 2
      test/parallel/test-net-server-max-connections.js

85
test/parallel/test-net-server-max-connections-close-makes-more-available.js

@ -0,0 +1,85 @@
'use strict';
var common = require('../common');
var assert = require('assert');
var net = require('net');
// Sets the server's maxConnections property to 1.
// Open 2 connections (connection 0 and connection 1).
// Connection 0 should be accepted.
// Connection 1 should be rejected.
// Closes connection 0.
// Open 2 more connections (connection 2 and 3).
// Connection 2 should be accepted.
// Connection 3 should be rejected.
var connections = [];
var received = [];
var sent = [];
var createConnection = function(index) {
console.error('creating connection ' + index);
return new Promise(function(resolve, reject) {
var connection = net.createConnection(common.PORT, function() {
var msg = '' + index;
console.error('sending message: ' + msg);
this.write(msg);
sent.push(msg);
});
connection.on('data', function(e) {
console.error('connection ' + index + ' received response');
resolve();
});
connection.on('end', function() {
console.error('ending ' + index);
resolve();
});
connections[index] = connection;
});
};
var closeConnection = function(index) {
console.error('closing connection ' + index);
return new Promise(function(resolve, reject) {
connections[index].on('end', function() {
resolve();
});
connections[index].end();
});
};
var server = net.createServer(function(socket) {
socket.on('data', function(data) {
console.error('received message: ' + data);
received.push('' + data);
socket.write('acknowledged');
});
});
server.maxConnections = 1;
server.listen(common.PORT, function() {
createConnection(0)
.then(createConnection.bind(null, 1))
.then(closeConnection.bind(null, 0))
.then(createConnection.bind(null, 2))
.then(createConnection.bind(null, 3))
.then(server.close.bind(server))
.then(closeConnection.bind(null, 2));
});
process.on('exit', function() {
// Confirm that all connections tried to send data...
assert.deepEqual(sent, [0, 1, 2, 3]);
// ...but that only connections 0 and 2 were successful.
assert.deepEqual(received, [0, 2]);
});
process.on('unhandledRejection', function() {
console.error('promise rejected');
assert.fail(null, null, 'A promise in the chain rejected');
});

2
test/parallel/test-net-server-max-connections.js

@ -7,8 +7,6 @@ var net = require('net');
// This test creates 200 connections to a server and sets the server's
// maxConnections property to 100. The first 100 connections make it through
// and the last 100 connections are rejected.
// TODO: test that the server can accept more connections after it reaches
// its maximum and some are closed.
var N = 200;
var count = 0;

Loading…
Cancel
Save