Renamed namespace to debug and added unit test for middleware

This commit is contained in:
Keith Holliday
2016-03-18 14:05:14 -05:00
parent e056a62af0
commit a3d7edd0c1
5 changed files with 59 additions and 23 deletions

View File

@@ -3,15 +3,19 @@ import {
generateUser, generateUser,
} from '../../../../helpers/api-v3-integration.helper'; } from '../../../../helpers/api-v3-integration.helper';
describe('POST /development/addHourglass', () => { describe('POST /debug/add-hourglass', () => {
let userToGetHourGlass; let userToGetHourGlass;
before(async () => { before(async () => {
userToGetHourGlass = await generateUser(); userToGetHourGlass = await generateUser();
}); });
after(() => {
nconf.set('IS_PROD', false);
});
it('adds Hourglass to the current user', async () => { it('adds Hourglass to the current user', async () => {
await userToGetHourGlass.post('/development/addHourglass'); await userToGetHourGlass.post('/debug/add-hourglass');
let userWithHourGlass = await userToGetHourGlass.get('/user'); let userWithHourGlass = await userToGetHourGlass.get('/user');
@@ -21,15 +25,11 @@ describe('POST /development/addHourglass', () => {
it('returns error when not in production mode', async () => { it('returns error when not in production mode', async () => {
nconf.set('IS_PROD', true); nconf.set('IS_PROD', true);
await expect(userToGetHourGlass.post('/development/addHourglass')) await expect(userToGetHourGlass.post('/debug/add-hourglass'))
.eventually.be.rejected.and.to.deep.equal({ .eventually.be.rejected.and.to.deep.equal({
code: 404, code: 404,
error: 'NotFound', error: 'NotFound',
message: 'Not found.', message: 'Not found.',
}); });
}); });
after(() => {
nconf.set('IS_PROD', false);
});
}); });

View File

@@ -3,15 +3,19 @@ import {
generateUser, generateUser,
} from '../../../../helpers/api-v3-integration.helper'; } from '../../../../helpers/api-v3-integration.helper';
describe('POST /development/addTenGems', () => { describe('POST /debug/add-ten-gems', () => {
let userToGainTenGems; let userToGainTenGems;
before(async () => { before(async () => {
userToGainTenGems = await generateUser(); userToGainTenGems = await generateUser();
}); });
after(() => {
nconf.set('IS_PROD', false);
});
it('adds ten gems to the current user', async () => { it('adds ten gems to the current user', async () => {
await userToGainTenGems.post('/development/addTenGems'); await userToGainTenGems.post('/debug/add-ten-gems');
let userWithTenGems = await userToGainTenGems.get('/user'); let userWithTenGems = await userToGainTenGems.get('/user');
@@ -21,15 +25,11 @@ describe('POST /development/addTenGems', () => {
it('returns error when not in production mode', async () => { it('returns error when not in production mode', async () => {
nconf.set('IS_PROD', true); nconf.set('IS_PROD', true);
await expect(userToGainTenGems.post('/development/addTenGems')) await expect(userToGainTenGems.post('/debug/add-ten-gems'))
.eventually.be.rejected.and.to.deep.equal({ .eventually.be.rejected.and.to.deep.equal({
code: 404, code: 404,
error: 'NotFound', error: 'NotFound',
message: 'Not found.', message: 'Not found.',
}); });
}); });
after(() => {
nconf.set('IS_PROD', false);
});
}); });

View File

@@ -0,0 +1,36 @@
/* eslint-disable global-require */
import {
generateRes,
generateReq,
generateNext,
} from '../../../../helpers/api-unit.helper';
import ensureDevelpmentMode from '../../../../../website/src/middlewares/api-v3/ensureDevelpmentMode';
import { NotFound } from '../../../../../website/src/libs/api-v3/errors';
import nconf from 'nconf';
describe('developmentMode middleware', () => {
let res, req, next;
beforeEach(() => {
res = generateRes();
req = generateReq();
next = generateNext();
});
it('returns not found when in production mode', () => {
sandbox.stub(nconf, 'get').withArgs('IS_PROD').returns(true);
ensureDevelpmentMode(req, res, next);
expect(next).to.be.calledWith(new NotFound());
});
it('passes when not in production', () => {
sandbox.stub(nconf, 'get').withArgs('IS_PROD').returns(false);
ensureDevelpmentMode(req, res, next);
expect(next).to.be.calledOnce;
expect(next.args[0]).to.be.empty;
});
});

View File

@@ -1,17 +1,17 @@
import { authWithHeaders } from '../../middlewares/api-v3/auth'; import { authWithHeaders } from '../../middlewares/api-v3/auth';
import cron from '../../middlewares/api-v3/cron'; import cron from '../../middlewares/api-v3/cron';
import checkForDevelopmentMode from '../../middlewares/api-v3/developmentMode'; import ensureDevelpmentMode from '../../middlewares/api-v3/ensureDevelpmentMode';
let api = {}; let api = {};
api.development = { api.debug = {
method: 'all', method: 'all',
url: '/development/*', url: '/debug/*',
middlewares: [checkForDevelopmentMode, authWithHeaders(), cron], middlewares: [ensureDevelpmentMode, authWithHeaders(), cron],
}; };
/** /**
* @api {post} /development/addTenGems Add ten gems to the current user * @api {post} /debug/add-ten-gems Add ten gems to the current user
* @apiVersion 3.0.0 * @apiVersion 3.0.0
* @apiName AddTenGems * @apiName AddTenGems
* @apiGroup Development * @apiGroup Development
@@ -20,7 +20,7 @@ api.development = {
*/ */
api.addTenGems = { api.addTenGems = {
method: 'POST', method: 'POST',
url: '/development/addTenGems', url: '/debug/add-ten-gems',
async handler (req, res) { async handler (req, res) {
let user = res.locals.user; let user = res.locals.user;
@@ -33,7 +33,7 @@ api.addTenGems = {
}; };
/** /**
* @api {post} /development/addHourglass Add Hourglass to the current user * @api {post} /debug/add-hourglass Add Hourglass to the current user
* @apiVersion 3.0.0 * @apiVersion 3.0.0
* @apiName AddHourglass * @apiName AddHourglass
* @apiGroup Development * @apiGroup Development
@@ -42,7 +42,7 @@ api.addTenGems = {
*/ */
api.addHourglass = { api.addHourglass = {
method: 'POST', method: 'POST',
url: '/development/addHourglass', url: '/debug/add-hourglass',
async handler (req, res) { async handler (req, res) {
let user = res.locals.user; let user = res.locals.user;

View File

@@ -3,7 +3,7 @@ import {
NotFound, NotFound,
} from '../../libs/api-v3/errors'; } from '../../libs/api-v3/errors';
module.exports = function checkForDevelopmentMode (req, res, next) { module.exports = function ensureDevelpmentMode (req, res, next) {
if (nconf.get('IS_PROD')) { if (nconf.get('IS_PROD')) {
next(new NotFound()); next(new NotFound());
} else { } else {