node/test/gc/test-http-client.js
Sakthipriyan Vairamani 612307564b test: make import common as the first line
The `test/common` module has the capability to identify if any variable
is leaked to the global scope and fail the test. So that has to be
imported at the beginning.

PR-URL: https://github.com/nodejs/node/pull/7786
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Rich Trott <rtrott@gmail.com>
2016-07-21 16:39:21 -07:00

70 lines
1.2 KiB
JavaScript

'use strict';
// just a simple http server and client.
require('../common');
function serverHandler(req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello World\n');
}
const http = require('http');
const weak = require('weak');
const assert = require('assert');
const todo = 500;
let done = 0;
let count = 0;
let countGC = 0;
console.log('We should do ' + todo + ' requests');
var server = http.createServer(serverHandler);
server.listen(0, getall);
function getall() {
if (count >= todo)
return;
(function() {
function cb(res) {
res.resume();
console.error('in cb');
done += 1;
res.on('end', global.gc);
}
var req = http.get({
hostname: 'localhost',
pathname: '/',
port: server.address().port
}, cb);
count++;
weak(req, afterGC);
})();
setImmediate(getall);
}
for (var i = 0; i < 10; i++)
getall();
function afterGC() {
countGC++;
}
setInterval(status, 1000).unref();
function status() {
global.gc();
console.log('Done: %d/%d', done, todo);
console.log('Collected: %d/%d', countGC, count);
if (done === todo) {
console.log('All should be collected now.');
assert(count === countGC);
process.exit(0);
}
}