mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-15 13:47:33 +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
156 lines
4.1 KiB
JavaScript
156 lines
4.1 KiB
JavaScript
import {
|
|
generateUser,
|
|
createAndPopulateGroup,
|
|
translate as t,
|
|
} from '../../../../../helpers/api-v3-integration.helper';
|
|
import { v4 as generateUUID } from 'uuid';
|
|
|
|
describe('POST /tasks/group/:groupid', () => {
|
|
let user, guild, manager;
|
|
let groupName = 'Test Public Guild';
|
|
let groupType = 'guild';
|
|
|
|
beforeEach(async () => {
|
|
user = await generateUser({balance: 1});
|
|
let { group, groupLeader, members } = await createAndPopulateGroup({
|
|
groupDetails: {
|
|
name: groupName,
|
|
type: groupType,
|
|
privacy: 'private',
|
|
},
|
|
members: 1,
|
|
});
|
|
|
|
guild = group;
|
|
user = groupLeader;
|
|
manager = members[0];
|
|
});
|
|
|
|
it('returns error when group is not found', async () => {
|
|
await expect(user.post(`/tasks/group/${generateUUID()}`, {
|
|
text: 'test habit',
|
|
type: 'habit',
|
|
up: false,
|
|
down: true,
|
|
notes: 1976,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('groupNotFound'),
|
|
});
|
|
});
|
|
|
|
it('returns error when user is not a member of the group', async () => {
|
|
let userWithoutChallenge = await generateUser();
|
|
|
|
await expect(userWithoutChallenge.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test habit',
|
|
type: 'habit',
|
|
up: false,
|
|
down: true,
|
|
notes: 1976,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('groupNotFound'),
|
|
});
|
|
});
|
|
|
|
it('returns error when non leader tries to create a task', async () => {
|
|
let userThatIsNotLeaderOfGroup = await generateUser({
|
|
guilds: [guild._id],
|
|
});
|
|
|
|
await expect(userThatIsNotLeaderOfGroup.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test habit',
|
|
type: 'habit',
|
|
up: false,
|
|
down: true,
|
|
notes: 1976,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('onlyGroupLeaderCanEditTasks'),
|
|
});
|
|
});
|
|
|
|
it('creates a habit', async () => {
|
|
let task = await user.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test habit',
|
|
type: 'habit',
|
|
up: false,
|
|
down: true,
|
|
notes: 1976,
|
|
});
|
|
|
|
let groupTask = await user.get(`/tasks/group/${guild._id}`);
|
|
|
|
expect(groupTask[0].group.id).to.equal(guild._id);
|
|
expect(task.text).to.eql('test habit');
|
|
expect(task.notes).to.eql('1976');
|
|
expect(task.type).to.eql('habit');
|
|
expect(task.up).to.eql(false);
|
|
expect(task.down).to.eql(true);
|
|
});
|
|
|
|
it('creates a todo', async () => {
|
|
let task = await user.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test todo',
|
|
type: 'todo',
|
|
notes: 1976,
|
|
});
|
|
|
|
let groupTask = await user.get(`/tasks/group/${guild._id}`);
|
|
|
|
expect(groupTask[0].group.id).to.equal(guild._id);
|
|
expect(task.text).to.eql('test todo');
|
|
expect(task.notes).to.eql('1976');
|
|
expect(task.type).to.eql('todo');
|
|
});
|
|
|
|
it('creates a daily', async () => {
|
|
let now = new Date();
|
|
let task = await user.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test daily',
|
|
type: 'daily',
|
|
notes: 1976,
|
|
frequency: 'daily',
|
|
everyX: 5,
|
|
startDate: now,
|
|
});
|
|
|
|
let groupTask = await user.get(`/tasks/group/${guild._id}`);
|
|
|
|
expect(groupTask[0].group.id).to.equal(guild._id);
|
|
expect(task.text).to.eql('test daily');
|
|
expect(task.notes).to.eql('1976');
|
|
expect(task.type).to.eql('daily');
|
|
expect(task.frequency).to.eql('daily');
|
|
expect(task.everyX).to.eql(5);
|
|
expect(new Date(task.startDate)).to.eql(now);
|
|
});
|
|
|
|
it('allows a manager to add a group task', async () => {
|
|
await user.post(`/groups/${guild._id}/add-manager`, {
|
|
managerId: manager._id,
|
|
});
|
|
|
|
let task = await manager.post(`/tasks/group/${guild._id}`, {
|
|
text: 'test habit',
|
|
type: 'habit',
|
|
up: false,
|
|
down: true,
|
|
notes: 1976,
|
|
});
|
|
|
|
let groupTask = await manager.get(`/tasks/group/${guild._id}`);
|
|
|
|
expect(groupTask[0].group.id).to.equal(guild._id);
|
|
expect(task.text).to.eql('test habit');
|
|
expect(task.notes).to.eql('1976');
|
|
expect(task.type).to.eql('habit');
|
|
expect(task.up).to.eql(false);
|
|
expect(task.down).to.eql(true);
|
|
});
|
|
});
|