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,
|
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);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
@@ -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);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
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 { 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;
|
||||||
|
|
||||||
@@ -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 {
|
||||||
Reference in New Issue
Block a user