Browse Source

improve tests

activeAddress
Ivan Socolsky 9 years ago
parent
commit
d6f9633a73
  1. 2
      lib/expressapp.js
  2. 26
      test/expressapp.js

2
lib/expressapp.js

@ -440,7 +440,7 @@ ExpressApp.prototype.start = function(opts, cb) {
router.get('/v1/notifications/', function(req, res) { router.get('/v1/notifications/', function(req, res) {
getServerWithAuth(req, res, function(server) { getServerWithAuth(req, res, function(server) {
var opts = { var opts = {
minTs: Math.max(+req.query.minTs, +Date.now() - (60 * 1000)), minTs: Math.max(+req.query.minTs || 0, +Date.now() - (60 * 1000)),
notificationId: req.query.notificationId, notificationId: req.query.notificationId,
}; };
server.getNotifications(opts, function(err, notifications) { server.getNotifications(opts, function(err, notifications) {

26
test/expressapp.js

@ -103,10 +103,10 @@ describe('ExpressApp', function() {
clock.restore(); clock.restore();
}); });
it('should fetch notifications from a specific id', function(done) { it('should fetch notifications from a specified id', function(done) {
start(TestExpressApp, function() { start(TestExpressApp, function() {
var requestOptions = { var requestOptions = {
url: testHost + ':' + testPort + config.basePath + '/v1/notifications' + '?notificationId=123&minTs=' + (Date.now() - 30000), url: testHost + ':' + testPort + config.basePath + '/v1/notifications' + '?notificationId=123',
headers: { headers: {
'x-identity': 'identity', 'x-identity': 'identity',
'x-signature': 'signature' 'x-signature': 'signature'
@ -118,6 +118,26 @@ describe('ExpressApp', function() {
body.should.equal('{}'); body.should.equal('{}');
server.getNotifications.calledWith({ server.getNotifications.calledWith({
notificationId: '123', notificationId: '123',
minTs: +Date.now() - 60000,
}).should.be.true;
done();
});
});
});
it('should allow custom minTs within limits', function(done) {
start(TestExpressApp, function() {
var requestOptions = {
url: testHost + ':' + testPort + config.basePath + '/v1/notifications' + '?minTs=' + (Date.now() - 30000),
headers: {
'x-identity': 'identity',
'x-signature': 'signature'
}
};
request(requestOptions, function(err, res, body) {
should.not.exist(err);
res.statusCode.should.equal(200);
server.getNotifications.calledWith({
notificationId: undefined,
minTs: +Date.now() - 30000, minTs: +Date.now() - 30000,
}).should.be.true; }).should.be.true;
done(); done();
@ -127,7 +147,7 @@ describe('ExpressApp', function() {
it('should limit minTs to 60 seconds', function(done) { it('should limit minTs to 60 seconds', function(done) {
start(TestExpressApp, function() { start(TestExpressApp, function() {
var requestOptions = { var requestOptions = {
url: testHost + ':' + testPort + config.basePath + '/v1/notifications' + '?minTs=1', url: testHost + ':' + testPort + config.basePath + '/v1/notifications' + '?minTs=' + (Date.now() - 90000),
headers: { headers: {
'x-identity': 'identity', 'x-identity': 'identity',
'x-signature': 'signature' 'x-signature': 'signature'

Loading…
Cancel
Save