restify-new-nodejs-compatible
Version:
REST framework
133 lines (125 loc) • 4.23 kB
JavaScript
;
/* eslint-disable func-names */
var assert = require('chai').assert;
var restify = require('../../lib/index.js');
var restifyClients = require('restify-clients');
var inflightRequestThrottle = restify.plugins.inflightRequestThrottle;
function fakeServer(count) {
return {
inflightRequests: function() {
return count;
}
};
}
describe('inlfightRequestThrottle', function() {
it('Unit: Should shed load', function(done) {
var logged = false;
var opts = { server: fakeServer(10), limit: 1 };
var plugin = inflightRequestThrottle(opts);
function send(body) {
assert(logged, 'Should have emitted a log');
assert.equal(body.statusCode, 503, 'Defaults to 503 status');
assert(body instanceof Error, 'Defaults to error body');
done();
}
function next(err) {
assert.equal(err.name, 'ServiceUnavailableError');
done();
}
function trace() {
logged = true;
}
var log = { trace: trace };
var fakeReq = { log: log };
plugin(fakeReq, { send: send }, next);
});
it('Unit: Should support custom response', function(done) {
var server = fakeServer(10);
var err = new Error('foo');
var opts = { server: server, limit: 1, err: err };
var plugin = inflightRequestThrottle(opts);
function send(body) {
assert.equal(body, err, 'Overrides body');
}
function next(nextErr) {
assert.equal(err, nextErr);
done();
}
var fakeReq = { log: { trace: function() {} } };
plugin(fakeReq, { send: send }, next);
});
it('Unit: Should let request through when not under load', function(done) {
var opts = { server: fakeServer(1), limit: 2 };
var plugin = inflightRequestThrottle(opts);
function send() {
assert(false, 'Should not call send');
}
function next(cont) {
assert.isUndefined(cont, 'Should call next');
done();
}
var fakeReq = { log: { trace: function() {} } };
plugin(fakeReq, { send: send }, next);
});
it('Integration: Should shed load', function(done) {
var server = restify.createServer();
var client = {
close: function() {}
};
var isDone = false;
var to;
function finish() {
if (isDone) {
return null;
}
clearTimeout(to);
isDone = true;
client.close();
server.close();
return done();
}
to = setTimeout(finish, 2000);
var err = new Error('foo');
err.statusCode = 555;
var opts = { server: server, limit: 1, err: err };
server.pre(inflightRequestThrottle(opts));
var RES;
server.get('/foo', function(req, res, next) {
if (RES) {
res.send(999);
} else {
RES = res;
}
});
server.listen(0, '127.0.0.1', function() {
client = restifyClients.createJsonClient({
url: 'http://127.0.0.1:' + server.address().port,
retry: false
});
client.get({ path: '/foo' }, function(e, _, res) {
assert(
e === null || e === undefined,
'First request isnt shed'
);
assert.equal(res.statusCode, 200, '200 returned on success');
finish();
});
client.get({ path: '/foo' }, function(e, _, res) {
assert(e, 'Second request is shed');
assert.equal(
e.name,
'InternalServerError',
'Default err returned'
);
assert.equal(
res.statusCode,
555,
'Default shed status code returned'
);
if (RES) {
RES.send(200);
}
});
});
});
});