'use strict'; // just like test/gc/http-client.js, // but with a timeout set function serverHandler(req, res) { setTimeout(function() { req.resume(); res.writeHead(200); res.end('hello\n'); }, 100); } var http = require('http'), weak = require('weak'), done = 0, count = 0, countGC = 0, todo = 550, common = require('../common'), assert = require('assert'), PORT = common.PORT; console.log('We should do ' + todo + ' requests'); var http = require('http'); var server = http.createServer(serverHandler); server.listen(PORT, getall); function getall() { if (count >= todo) return; (function() { function cb(res) { res.resume(); done += 1; statusLater(); } var req = http.get({ hostname: 'localhost', pathname: '/', port: PORT }, cb); req.on('error', cb); req.setTimeout(10, function() { console.log('timeout (expected)'); }); count++; weak(req, afterGC); })(); setImmediate(getall); } for (var i = 0; i < 10; i++) getall(); function afterGC() { countGC ++; } var timer; function statusLater() { gc(); if (timer) clearTimeout(timer); timer = setTimeout(status, 1); } function status() { 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); } }