You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

133 lines
2.7 KiB

'use strict';
// Regression test for GH-784
// https://github.com/joyent/node/issues/784
//
// The test works by making a total of 8 requests to the server. The first
// two are made with the server off - they should come back as ECONNREFUSED.
// The next two are made with server on - they should come back successful.
// The next two are made with the server off - and so on. Without the fix
// we were experiencing parse errors and instead of ECONNREFUSED.
const common = require('../common');
const http = require('http');
const assert = require('assert');
const server = http.createServer(function(req, res) {
let body = '';
req.setEncoding('utf8');
req.on('data', function(chunk) {
body += chunk;
});
req.on('end', function() {
assert.strictEqual('PING', body);
res.writeHead(200);
res.end('PONG');
});
});
server.on('listening', pingping);
function serverOn() {
console.error('Server ON');
server.listen(common.PORT);
}
function serverOff() {
console.error('Server OFF');
server.close();
pingping();
}
const responses = [];
function afterPing(result) {
responses.push(result);
console.error(`afterPing. responses.length = ${responses.length}`);
switch (responses.length) {
case 2:
assert.ok(/ECONNREFUSED/.test(responses[0]));
assert.ok(/ECONNREFUSED/.test(responses[1]));
serverOn();
break;
case 4:
assert.ok(/success/.test(responses[2]));
assert.ok(/success/.test(responses[3]));
serverOff();
break;
case 6:
assert.ok(/ECONNREFUSED/.test(responses[4]));
assert.ok(/ECONNREFUSED/.test(responses[5]));
serverOn();
break;
case 8:
assert.ok(/success/.test(responses[6]));
assert.ok(/success/.test(responses[7]));
server.close();
// we should go to process.on('exit') from here.
break;
}
}
function ping() {
console.error('making req');
const opt = {
port: common.PORT,
path: '/ping',
method: 'POST'
};
const req = http.request(opt, function(res) {
let body = '';
res.setEncoding('utf8');
res.on('data', function(chunk) {
body += chunk;
});
res.on('end', function() {
assert.strictEqual('PONG', body);
assert.ok(!hadError);
gotEnd = true;
afterPing('success');
});
});
req.end('PING');
let gotEnd = false;
let hadError = false;
req.on('error', function(error) {
console.log(`Error making ping req: ${error}`);
hadError = true;
assert.ok(!gotEnd);
afterPing(error.message);
});
}
function pingping() {
ping();
ping();
}
pingping();
process.on('exit', function() {
console.error("process.on('exit')");
console.error(responses);
assert.strictEqual(8, responses.length);
});