mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 06:07:21 +01:00
* Added abiltiy to add group managers * Added ability to remove managers * Added ability for managers to add group tasks * Allower managers to assign tasks * Allowed managers to unassign tasks * Allow managers to delete group tasks * Allowed managers to approve * Added initial ui * Added approval view for managers * Allowed managers to edit * Fixed lint issues * Added spacing to buttons * Removed leader from selection of group managers * Code review updates * Ensured approvals are only done once * Added ability for parties to add managers * Add notifications to all managers when approval is requests * Removed tasks need approval notifications from all managers when task is approve * Fixed linting issues * Hid add managers UI from groups that are not subscribed * Removed let from front end * Fixed issues with post task url params * Fixed string locales * Removed extra limited strings * Added cannotedit tasks function * Added limit fields and notification check by taskId * Localized string and other minor issues * Added manager and leader indicator * Added group notifications refresh on sync * Added close button for group notifications * Removed group approval notifications when manager is removed * Moved leader/manager indicators to after hp * Added manager fields to groups * Spelling and syntax fixes
132 lines
3.6 KiB
JavaScript
132 lines
3.6 KiB
JavaScript
import {
|
|
translate as t,
|
|
createAndPopulateGroup,
|
|
} from '../../../../../helpers/api-integration/v3';
|
|
import { find } from 'lodash';
|
|
|
|
describe('Groups DELETE /tasks/:id', () => {
|
|
let user, guild, member, member2, task;
|
|
|
|
function findAssignedTask (memberTask) {
|
|
return memberTask.group.id === guild._id;
|
|
}
|
|
|
|
beforeEach(async () => {
|
|
let {group, members, groupLeader} = await createAndPopulateGroup({
|
|
groupDetails: {
|
|
name: 'Test Guild',
|
|
type: 'guild',
|
|
},
|
|
members: 2,
|
|
});
|
|
|
|
guild = group;
|
|
user = groupLeader;
|
|
member = members[0];
|
|
member2 = members[1];
|
|
|
|
task = await user.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test habit',
|
|
type: 'habit',
|
|
up: false,
|
|
down: true,
|
|
notes: 1976,
|
|
});
|
|
|
|
await user.post(`/tasks/${task._id}/assign/${member._id}`);
|
|
await user.post(`/tasks/${task._id}/assign/${member2._id}`);
|
|
});
|
|
|
|
it('deletes a group task', async () => {
|
|
await user.del(`/tasks/${task._id}`);
|
|
|
|
await expect(user.get(`/tasks/${task._id}`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('taskNotFound'),
|
|
});
|
|
});
|
|
|
|
it('allows a manager to delete a group task', async () => {
|
|
await user.post(`/groups/${guild._id}/add-manager`, {
|
|
managerId: member2._id,
|
|
});
|
|
|
|
await member2.del(`/tasks/${task._id}`);
|
|
|
|
await expect(user.get(`/tasks/${task._id}`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('taskNotFound'),
|
|
});
|
|
});
|
|
|
|
it('unlinks assigned user', async () => {
|
|
await user.del(`/tasks/${task._id}`);
|
|
|
|
let memberTasks = await member.get('/tasks/user');
|
|
let syncedTask = find(memberTasks, findAssignedTask);
|
|
|
|
expect(syncedTask.group.broken).to.equal('TASK_DELETED');
|
|
});
|
|
|
|
it('unlinks all assigned users', async () => {
|
|
await user.del(`/tasks/${task._id}`);
|
|
|
|
let memberTasks = await member.get('/tasks/user');
|
|
let syncedTask = find(memberTasks, findAssignedTask);
|
|
|
|
let member2Tasks = await member2.get('/tasks/user');
|
|
let member2SyncedTask = find(member2Tasks, findAssignedTask);
|
|
|
|
expect(syncedTask.group.broken).to.equal('TASK_DELETED');
|
|
expect(member2SyncedTask.group.broken).to.equal('TASK_DELETED');
|
|
});
|
|
|
|
it('prevents a user from deleting a task they are assigned to', async () => {
|
|
let memberTasks = await member.get('/tasks/user');
|
|
let syncedTask = find(memberTasks, findAssignedTask);
|
|
|
|
await expect(member.del(`/tasks/${syncedTask._id}`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('cantDeleteAssignedGroupTasks'),
|
|
});
|
|
});
|
|
|
|
it('allows a user to delete a broken task', async () => {
|
|
let memberTasks = await member.get('/tasks/user');
|
|
let syncedTask = find(memberTasks, findAssignedTask);
|
|
|
|
await user.del(`/tasks/${task._id}`);
|
|
|
|
await member.del(`/tasks/${syncedTask._id}`);
|
|
|
|
await expect(member.get(`/tasks/${syncedTask._id}`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: 'Task not found.',
|
|
});
|
|
});
|
|
|
|
it('allows a user to delete a task after leaving a group', async () => {
|
|
let memberTasks = await member.get('/tasks/user');
|
|
let syncedTask = find(memberTasks, findAssignedTask);
|
|
|
|
await member.post(`/groups/${guild._id}/leave`);
|
|
|
|
await member.del(`/tasks/${syncedTask._id}`);
|
|
|
|
await expect(member.get(`/tasks/${syncedTask._id}`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: 'Task not found.',
|
|
});
|
|
});
|
|
});
|