mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 15:17:25 +01:00
Renamed namespace to debug and added unit test for middleware
This commit is contained in:
@@ -3,15 +3,19 @@ import {
|
||||
generateUser,
|
||||
} from '../../../../helpers/api-v3-integration.helper';
|
||||
|
||||
describe('POST /development/addHourglass', () => {
|
||||
describe('POST /debug/add-hourglass', () => {
|
||||
let userToGetHourGlass;
|
||||
|
||||
before(async () => {
|
||||
userToGetHourGlass = await generateUser();
|
||||
});
|
||||
|
||||
after(() => {
|
||||
nconf.set('IS_PROD', false);
|
||||
});
|
||||
|
||||
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');
|
||||
|
||||
@@ -21,15 +25,11 @@ describe('POST /development/addHourglass', () => {
|
||||
it('returns error when not in production mode', async () => {
|
||||
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({
|
||||
code: 404,
|
||||
error: 'NotFound',
|
||||
message: 'Not found.',
|
||||
});
|
||||
});
|
||||
|
||||
after(() => {
|
||||
nconf.set('IS_PROD', false);
|
||||
});
|
||||
});
|
||||
@@ -3,15 +3,19 @@ import {
|
||||
generateUser,
|
||||
} from '../../../../helpers/api-v3-integration.helper';
|
||||
|
||||
describe('POST /development/addTenGems', () => {
|
||||
describe('POST /debug/add-ten-gems', () => {
|
||||
let userToGainTenGems;
|
||||
|
||||
before(async () => {
|
||||
userToGainTenGems = await generateUser();
|
||||
});
|
||||
|
||||
after(() => {
|
||||
nconf.set('IS_PROD', false);
|
||||
});
|
||||
|
||||
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');
|
||||
|
||||
@@ -21,15 +25,11 @@ describe('POST /development/addTenGems', () => {
|
||||
it('returns error when not in production mode', async () => {
|
||||
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({
|
||||
code: 404,
|
||||
error: 'NotFound',
|
||||
message: 'Not found.',
|
||||
});
|
||||
});
|
||||
|
||||
after(() => {
|
||||
nconf.set('IS_PROD', false);
|
||||
});
|
||||
});
|
||||
36
test/api/v3/unit/middlewares/ensureDevelpmentMode.js
Normal file
36
test/api/v3/unit/middlewares/ensureDevelpmentMode.js
Normal 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;
|
||||
});
|
||||
});
|
||||
@@ -1,17 +1,17 @@
|
||||
import { authWithHeaders } from '../../middlewares/api-v3/auth';
|
||||
import cron from '../../middlewares/api-v3/cron';
|
||||
import checkForDevelopmentMode from '../../middlewares/api-v3/developmentMode';
|
||||
import ensureDevelpmentMode from '../../middlewares/api-v3/ensureDevelpmentMode';
|
||||
|
||||
let api = {};
|
||||
|
||||
api.development = {
|
||||
api.debug = {
|
||||
method: 'all',
|
||||
url: '/development/*',
|
||||
middlewares: [checkForDevelopmentMode, authWithHeaders(), cron],
|
||||
url: '/debug/*',
|
||||
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
|
||||
* @apiName AddTenGems
|
||||
* @apiGroup Development
|
||||
@@ -20,7 +20,7 @@ api.development = {
|
||||
*/
|
||||
api.addTenGems = {
|
||||
method: 'POST',
|
||||
url: '/development/addTenGems',
|
||||
url: '/debug/add-ten-gems',
|
||||
async handler (req, res) {
|
||||
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
|
||||
* @apiName AddHourglass
|
||||
* @apiGroup Development
|
||||
@@ -42,7 +42,7 @@ api.addTenGems = {
|
||||
*/
|
||||
api.addHourglass = {
|
||||
method: 'POST',
|
||||
url: '/development/addHourglass',
|
||||
url: '/debug/add-hourglass',
|
||||
async handler (req, res) {
|
||||
let user = res.locals.user;
|
||||
|
||||
@@ -3,7 +3,7 @@ import {
|
||||
NotFound,
|
||||
} from '../../libs/api-v3/errors';
|
||||
|
||||
module.exports = function checkForDevelopmentMode (req, res, next) {
|
||||
module.exports = function ensureDevelpmentMode (req, res, next) {
|
||||
if (nconf.get('IS_PROD')) {
|
||||
next(new NotFound());
|
||||
} else {
|
||||
Reference in New Issue
Block a user