/**
request-time.js
*/
module.exports = function(opts) {
var time = opts.time || 100;
return function(req, res, next) {
var timer = setTimeout(function() {
console.log('%s %s taking too long', req.method, req.url);
}, time);
var end = res.end;
res.end = function(chunk, encoding) {
res.end = end;
res.end(chunk, encoding);
clearTimeout(timer);
};
next();
};
};
/**
server.js
*/
var connect = require('connect'),
time = require('./request-time');
var server = connect.createServer();
//server.use(connect.logger('dev'));
server.use(time({time: 500}));
server.use(function(req, res,next) {
if ('/a' == req.url) {
res.writeHead(200);
res.end('Fast!');
} else {
next();
}
});
server.use(function(req, res,next) {
if ('/b' == req.url) {
setTimeout(function() {
res.writeHead(200);
res.end('Slow');
}, 1000);
} else {
next();
}
});
server.listen(3000);