mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-19 07:37:25 +01:00
fix errorHandler tests, add tests for res.respond
This commit is contained in:
@@ -5,6 +5,8 @@ import {
|
|||||||
} from '../../../../helpers/api-unit.helper';
|
} from '../../../../helpers/api-unit.helper';
|
||||||
|
|
||||||
import errorHandler from '../../../../../website/src/middlewares/api-v3/errorHandler';
|
import errorHandler from '../../../../../website/src/middlewares/api-v3/errorHandler';
|
||||||
|
import responseMiddleware from '../../../../../website/src/middlewares/api-v3/response';
|
||||||
|
import getUserLanguage from '../../../../../website/src/middlewares/api-v3/getUserLanguage';
|
||||||
|
|
||||||
import { BadRequest } from '../../../../../website/src/libs/api-v3/errors';
|
import { BadRequest } from '../../../../../website/src/libs/api-v3/errors';
|
||||||
import logger from '../../../../../website/src/libs/api-v3/logger';
|
import logger from '../../../../../website/src/libs/api-v3/logger';
|
||||||
@@ -16,6 +18,8 @@ describe('errorHandler', () => {
|
|||||||
res = generateRes();
|
res = generateRes();
|
||||||
req = generateReq();
|
req = generateReq();
|
||||||
next = generateNext();
|
next = generateNext();
|
||||||
|
responseMiddleware(req, res, next);
|
||||||
|
getUserLanguage(req, res, next);
|
||||||
|
|
||||||
sandbox.stub(logger, 'error');
|
sandbox.stub(logger, 'error');
|
||||||
});
|
});
|
||||||
@@ -30,6 +34,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(500);
|
expect(res.status).to.be.calledWith(500);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: 'InternalServerError',
|
error: 'InternalServerError',
|
||||||
message: 'An unexpected error occurred.',
|
message: 'An unexpected error occurred.',
|
||||||
});
|
});
|
||||||
@@ -46,6 +51,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(400);
|
expect(res.status).to.be.calledWith(400);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: 'Error',
|
error: 'Error',
|
||||||
message: 'Error message',
|
message: 'Error message',
|
||||||
});
|
});
|
||||||
@@ -62,6 +68,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(500);
|
expect(res.status).to.be.calledWith(500);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: 'InternalServerError',
|
error: 'InternalServerError',
|
||||||
message: 'An unexpected error occurred.',
|
message: 'An unexpected error occurred.',
|
||||||
});
|
});
|
||||||
@@ -77,6 +84,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(400);
|
expect(res.status).to.be.calledWith(400);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: 'BadRequest',
|
error: 'BadRequest',
|
||||||
message: 'Bad request.',
|
message: 'Bad request.',
|
||||||
});
|
});
|
||||||
@@ -93,6 +101,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(error.statusCode);
|
expect(res.status).to.be.calledWith(error.statusCode);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: error.name,
|
error: error.name,
|
||||||
message: error.message,
|
message: error.message,
|
||||||
});
|
});
|
||||||
@@ -108,6 +117,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(400);
|
expect(res.status).to.be.calledWith(400);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: 'BadRequest',
|
error: 'BadRequest',
|
||||||
message: 'Invalid request parameters.',
|
message: 'Invalid request parameters.',
|
||||||
errors: error,
|
errors: error,
|
||||||
@@ -133,6 +143,7 @@ describe('errorHandler', () => {
|
|||||||
|
|
||||||
expect(res.status).to.be.calledWith(400);
|
expect(res.status).to.be.calledWith(400);
|
||||||
expect(res.json).to.be.calledWith({
|
expect(res.json).to.be.calledWith({
|
||||||
|
success: false,
|
||||||
error: 'BadRequest',
|
error: 'BadRequest',
|
||||||
message: 'User validation failed.',
|
message: 'User validation failed.',
|
||||||
errors: [
|
errors: [
|
||||||
@@ -154,11 +165,4 @@ describe('errorHandler', () => {
|
|||||||
fullError: error,
|
fullError: error,
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('does not send error if error is not defined', () => {
|
|
||||||
errorHandler(null, req, res, next);
|
|
||||||
|
|
||||||
expect(next).to.be.calledOnce;
|
|
||||||
expect(res.status).to.not.be.called;
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|||||||
51
test/api/v3/unit/middlewares/response.js
Normal file
51
test/api/v3/unit/middlewares/response.js
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
import {
|
||||||
|
generateRes,
|
||||||
|
generateReq,
|
||||||
|
generateNext,
|
||||||
|
} from '../../../../helpers/api-unit.helper';
|
||||||
|
import responseMiddleware from '../../../../../website/src/middlewares/api-v3/response'
|
||||||
|
|
||||||
|
describe('response middleware', function() {
|
||||||
|
let res, req, next;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
res = generateRes();
|
||||||
|
req = generateReq();
|
||||||
|
next = generateNext();
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
it('attaches respond method to res', function() {
|
||||||
|
responseMiddleware(req, res, next);
|
||||||
|
|
||||||
|
expect(res.respond).to.exist;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can be used to respond to requests', function() {
|
||||||
|
responseMiddleware(req, res, next);
|
||||||
|
res.respond(200, {field: 1});
|
||||||
|
|
||||||
|
expect(res.status).to.be.calledOnce;
|
||||||
|
expect(res.json).to.be.calledOnce;
|
||||||
|
|
||||||
|
expect(res.status).to.be.calledWith(200);
|
||||||
|
expect(res.json).to.be.calledWith({
|
||||||
|
field: 1,
|
||||||
|
success: true,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('treats status >= 400 as failures', function() {
|
||||||
|
responseMiddleware(req, res, next);
|
||||||
|
res.respond(403, {field: 1});
|
||||||
|
|
||||||
|
expect(res.status).to.be.calledOnce;
|
||||||
|
expect(res.json).to.be.calledOnce;
|
||||||
|
|
||||||
|
expect(res.status).to.be.calledWith(403);
|
||||||
|
expect(res.json).to.be.calledWith({
|
||||||
|
field: 1,
|
||||||
|
success: false,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -8,9 +8,7 @@ import {
|
|||||||
} from '../../libs/api-v3/errors';
|
} from '../../libs/api-v3/errors';
|
||||||
import { map } from 'lodash';
|
import { map } from 'lodash';
|
||||||
|
|
||||||
export default function errorHandler (err, req, res, next) {
|
export default function errorHandler (err, req, res, next) { // eslint-disable-line no-unused-vars
|
||||||
if (!err) return next();
|
|
||||||
|
|
||||||
// Log the original error with some metadata
|
// Log the original error with some metadata
|
||||||
let stack = err.stack || err.message || err;
|
let stack = err.stack || err.message || err;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user