mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 22:57:21 +01:00
* move translatable string to apiMessages * use apiMessages instead of res.t for groupIdRequired / keepOrRemove * move pageMustBeNumber to apiMessages * change apimessages * move missingKeyParam to apiMessages * move more strings to apiMessages * fix lint * revert lodash imports to fix tests * fix webhook test * fix test * rollback key change of `keepOrRemove` * remove unneeded `req.language` param * extract more messages from i18n * add missing `missingTypeParam` message * Split api- and commonMessages * fix test * fix sanity * merge messages to an object, rename commonMessage to errorMessage * apiMessages -> apiError, commonMessages -> errorMessage, extract messages to separate objects * fix test * module.exports
60 lines
1.6 KiB
JavaScript
60 lines
1.6 KiB
JavaScript
import {
|
|
generateUser,
|
|
translate as t,
|
|
resetHabiticaDB,
|
|
} from '../../../../helpers/api-v3-integration.helper';
|
|
import couponCode from 'coupon-code';
|
|
import apiError from '../../../../../website/server/libs/apiError';
|
|
|
|
describe('POST /coupons/generate/:event', () => {
|
|
let user;
|
|
before(async () => {
|
|
await resetHabiticaDB();
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
user = await generateUser({
|
|
'contributor.sudo': true,
|
|
});
|
|
});
|
|
|
|
it('returns an error if user has no sudo permission', async () => {
|
|
await user.update({
|
|
'contributor.sudo': false,
|
|
});
|
|
|
|
await expect(user.post('/coupons/generate/aaa')).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: apiError('noSudoAccess'),
|
|
});
|
|
});
|
|
|
|
it('returns an error if event is invalid', async () => {
|
|
await expect(user.post('/coupons/generate/notValid?count=1')).to.eventually.be.rejected.and.eql({
|
|
code: 400,
|
|
error: 'BadRequest',
|
|
message: 'Coupon validation failed',
|
|
});
|
|
});
|
|
|
|
it('returns an error if count is missing', async () => {
|
|
await expect(user.post('/coupons/generate/notValid')).to.eventually.be.rejected.and.eql({
|
|
code: 400,
|
|
error: 'BadRequest',
|
|
message: t('invalidReqParams'),
|
|
});
|
|
});
|
|
|
|
it('should generate coupons', async () => {
|
|
await user.update({
|
|
'contributor.sudo': true,
|
|
});
|
|
|
|
let coupons = await user.post('/coupons/generate/wondercon?count=2');
|
|
expect(coupons.length).to.equal(2);
|
|
expect(coupons[0].event).to.equal('wondercon');
|
|
expect(couponCode.validate(coupons[1]._id)).to.not.equal(''); // '' means invalid
|
|
});
|
|
});
|