mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 13:17:24 +01:00
* remove some unused dependencies * update mongoose version * make common tests pass * Make unit tests pass * make api v3 integration tests pass * fix lint issues * fix issue with package-lock * fix(lint): we don't need no .js * fix(lint): update to latest config-habitrpg * chore(npm): update package locks * fix(test): replace deprecated fn * chore(package): update eslint-habitrpg again * fix(lint): server linting * fix(lint): client linting * fix(client): correct mangled common imports * chore(npm): update package-locks * fix(lint): punctuation, module --------- Co-authored-by: SabreCat <sabrecat@gmail.com> Co-authored-by: SabreCat <sabe@habitica.com>
94 lines
2.8 KiB
JavaScript
94 lines
2.8 KiB
JavaScript
import { v4 as generateUUID } from 'uuid';
|
|
import {
|
|
generateUser,
|
|
generateChallenge,
|
|
createAndPopulateGroup,
|
|
sleep,
|
|
checkExistence,
|
|
translate as t,
|
|
} from '../../../../helpers/api-integration/v3';
|
|
|
|
describe('DELETE /challenges/:challengeId', () => {
|
|
it('returns error when challengeId is not a valid UUID', async () => {
|
|
const user = await generateUser();
|
|
await expect(user.del('/challenges/test')).to.eventually.be.rejected.and.eql({
|
|
code: 400,
|
|
error: 'BadRequest',
|
|
message: t('invalidReqParams'),
|
|
});
|
|
});
|
|
|
|
it('returns error when challengeId is not for a valid challenge', async () => {
|
|
const user = await generateUser();
|
|
|
|
await expect(user.del(`/challenges/${generateUUID()}`)).to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('challengeNotFound'),
|
|
});
|
|
});
|
|
|
|
context('Deleting a valid challenge', () => {
|
|
let groupLeader;
|
|
let group;
|
|
let challenge;
|
|
const taskText = 'A challenge task text';
|
|
|
|
beforeEach(async () => {
|
|
const populatedGroup = await createAndPopulateGroup();
|
|
|
|
groupLeader = populatedGroup.groupLeader;
|
|
group = populatedGroup.group;
|
|
|
|
challenge = await generateChallenge(groupLeader, group);
|
|
await groupLeader.post(`/challenges/${challenge._id}/join`);
|
|
|
|
await groupLeader.post(`/tasks/challenge/${challenge._id}`, [
|
|
{ type: 'habit', text: taskText },
|
|
]);
|
|
|
|
await challenge.sync();
|
|
});
|
|
|
|
it('returns an error when user doesn\'t have permissions to delete the challenge', async () => {
|
|
const user = await generateUser();
|
|
|
|
await expect(user.del(`/challenges/${challenge._id}`)).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('onlyLeaderDeleteChal'),
|
|
});
|
|
});
|
|
|
|
it('deletes challenge', async () => {
|
|
await groupLeader.del(`/challenges/${challenge._id}`);
|
|
|
|
await sleep(0.5);
|
|
|
|
await expect(checkExistence('challenges', challenge._id)).to.eventually.equal(false);
|
|
});
|
|
|
|
it('refunds gems to group leader', async () => {
|
|
const oldBalance = (await groupLeader.sync()).balance;
|
|
|
|
await groupLeader.del(`/challenges/${challenge._id}`);
|
|
|
|
await sleep(0.5);
|
|
|
|
await expect(groupLeader.sync()).to.eventually.have.property('balance', oldBalance + challenge.prize / 4);
|
|
});
|
|
|
|
it('sets broken and doesn\'t set winner flags for user\'s challenge tasks', async () => {
|
|
await groupLeader.del(`/challenges/${challenge._id}`);
|
|
|
|
await sleep(0.5);
|
|
|
|
const tasks = await groupLeader.get('/tasks/user');
|
|
const testTask = _.find(tasks, task => task.text === taskText);
|
|
|
|
expect(testTask.challenge.broken).to.eql('CHALLENGE_DELETED');
|
|
expect(testTask.challenge.winner).to.be.undefined;
|
|
});
|
|
});
|
|
});
|