mirror of
https://github.com/nodejs/node.git
synced 2025-05-08 18:53:34 +00:00

Remove unneeded timers from some tests and move others from parallel testing to sequential testing. This is to resolve test failures on freebsd10-64 on CI. The failures are all due to timers firing later than expected. Timers firing later than they are set for can happen on resource-constrained hosts and is not a bug. In general, it may be wise to put tests that depend on timing into sequential testing rather than parallel testing, as the timing can be affected by other simultaneously-running test processes. Fixes: https://github.com/nodejs/node/issues/8041 Fixes: https://github.com/nodejs/node/issues/9227 PR-URL: https://github.com/nodejs/node/pull/9317 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Gibson Fahnestock <gibfahn@gmail.com> Reviewed-By: Julien Gilli <jgilli@nodejs.org> Reviewed-By: Johan Bergstrom <bugs@bergstroem.nu> Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com>
49 lines
1.0 KiB
JavaScript
49 lines
1.0 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
|
|
var ntimeouts = 0;
|
|
var nchunks = 0;
|
|
|
|
process.on('exit', function() {
|
|
assert.equal(ntimeouts, 1);
|
|
assert.equal(nchunks, 2);
|
|
});
|
|
|
|
const options = {
|
|
method: 'GET',
|
|
port: undefined,
|
|
host: '127.0.0.1',
|
|
path: '/'
|
|
};
|
|
|
|
const server = http.createServer(function(req, res) {
|
|
res.writeHead(200, {'Content-Length': '2'});
|
|
res.write('*');
|
|
setTimeout(function() { res.end('*'); }, common.platformTimeout(100));
|
|
});
|
|
|
|
server.listen(0, options.host, function() {
|
|
options.port = this.address().port;
|
|
const req = http.request(options, onresponse);
|
|
req.end();
|
|
|
|
function onresponse(res) {
|
|
req.setTimeout(50, function() {
|
|
assert.equal(nchunks, 1); // should have received the first chunk by now
|
|
ntimeouts++;
|
|
});
|
|
|
|
res.on('data', function(data) {
|
|
assert.equal('' + data, '*');
|
|
nchunks++;
|
|
});
|
|
|
|
res.on('end', function() {
|
|
assert.equal(nchunks, 2);
|
|
server.close();
|
|
});
|
|
}
|
|
});
|