mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-10-27 19:22:55 +01:00
* Added flagging to show to admins * Fixed filters in my guilds * Fixed login incentives style * Added inital rage bar * Added categoires to get group * Updated profile stats page * Added stat allocation * Updated tests to include categoires * Fixed lint issue * Added another lint fix
228 lines
7.3 KiB
JavaScript
228 lines
7.3 KiB
JavaScript
import {
|
|
generateUser,
|
|
generateChallenge,
|
|
createAndPopulateGroup,
|
|
} from '../../../../helpers/api-v3-integration.helper';
|
|
|
|
describe('GET challenges/user', () => {
|
|
context('no official challenges', () => {
|
|
let user, member, nonMember, challenge, challenge2, publicGuild;
|
|
|
|
before(async () => {
|
|
let { group, groupLeader, members } = await createAndPopulateGroup({
|
|
groupDetails: {
|
|
name: 'TestGuild',
|
|
type: 'guild',
|
|
privacy: 'public',
|
|
},
|
|
members: 1,
|
|
});
|
|
|
|
user = groupLeader;
|
|
publicGuild = group;
|
|
member = members[0];
|
|
nonMember = await generateUser();
|
|
|
|
challenge = await generateChallenge(user, group);
|
|
challenge2 = await generateChallenge(user, group);
|
|
});
|
|
|
|
it('should return challenges user has joined', async () => {
|
|
await nonMember.post(`/challenges/${challenge._id}/join`);
|
|
|
|
let challenges = await nonMember.get('/challenges/user');
|
|
|
|
let foundChallenge = _.find(challenges, { _id: challenge._id });
|
|
expect(foundChallenge).to.exist;
|
|
expect(foundChallenge.leader).to.eql({
|
|
_id: publicGuild.leader._id,
|
|
id: publicGuild.leader._id,
|
|
profile: {name: user.profile.name},
|
|
});
|
|
expect(foundChallenge.group).to.eql({
|
|
_id: publicGuild._id,
|
|
categories: [],
|
|
id: publicGuild._id,
|
|
type: publicGuild.type,
|
|
privacy: publicGuild.privacy,
|
|
name: publicGuild.name,
|
|
summary: publicGuild.name,
|
|
leader: publicGuild.leader._id,
|
|
});
|
|
});
|
|
|
|
it('should return challenges user has created', async () => {
|
|
let challenges = await user.get('/challenges/user');
|
|
|
|
let foundChallenge1 = _.find(challenges, { _id: challenge._id });
|
|
expect(foundChallenge1).to.exist;
|
|
expect(foundChallenge1.leader).to.eql({
|
|
_id: publicGuild.leader._id,
|
|
id: publicGuild.leader._id,
|
|
profile: {name: user.profile.name},
|
|
});
|
|
expect(foundChallenge1.group).to.eql({
|
|
_id: publicGuild._id,
|
|
categories: [],
|
|
id: publicGuild._id,
|
|
type: publicGuild.type,
|
|
privacy: publicGuild.privacy,
|
|
name: publicGuild.name,
|
|
summary: publicGuild.name,
|
|
leader: publicGuild.leader._id,
|
|
});
|
|
let foundChallenge2 = _.find(challenges, { _id: challenge2._id });
|
|
expect(foundChallenge2).to.exist;
|
|
expect(foundChallenge2.leader).to.eql({
|
|
_id: publicGuild.leader._id,
|
|
id: publicGuild.leader._id,
|
|
profile: {name: user.profile.name},
|
|
});
|
|
expect(foundChallenge2.group).to.eql({
|
|
_id: publicGuild._id,
|
|
categories: [],
|
|
id: publicGuild._id,
|
|
type: publicGuild.type,
|
|
privacy: publicGuild.privacy,
|
|
name: publicGuild.name,
|
|
summary: publicGuild.name,
|
|
leader: publicGuild.leader._id,
|
|
});
|
|
});
|
|
|
|
it('should return challenges in user\'s group', async () => {
|
|
let challenges = await member.get('/challenges/user');
|
|
|
|
let foundChallenge1 = _.find(challenges, { _id: challenge._id });
|
|
expect(foundChallenge1).to.exist;
|
|
expect(foundChallenge1.leader).to.eql({
|
|
_id: publicGuild.leader._id,
|
|
id: publicGuild.leader._id,
|
|
profile: {name: user.profile.name},
|
|
});
|
|
expect(foundChallenge1.group).to.eql({
|
|
_id: publicGuild._id,
|
|
categories: [],
|
|
id: publicGuild._id,
|
|
type: publicGuild.type,
|
|
privacy: publicGuild.privacy,
|
|
name: publicGuild.name,
|
|
summary: publicGuild.name,
|
|
leader: publicGuild.leader._id,
|
|
});
|
|
let foundChallenge2 = _.find(challenges, { _id: challenge2._id });
|
|
expect(foundChallenge2).to.exist;
|
|
expect(foundChallenge2.leader).to.eql({
|
|
_id: publicGuild.leader._id,
|
|
id: publicGuild.leader._id,
|
|
profile: {name: user.profile.name},
|
|
});
|
|
expect(foundChallenge2.group).to.eql({
|
|
_id: publicGuild._id,
|
|
categories: [],
|
|
id: publicGuild._id,
|
|
type: publicGuild.type,
|
|
privacy: publicGuild.privacy,
|
|
name: publicGuild.name,
|
|
summary: publicGuild.name,
|
|
leader: publicGuild.leader._id,
|
|
});
|
|
});
|
|
|
|
it('should return not return challenges in user groups if we send member true param', async () => {
|
|
let challenges = await member.get(`/challenges/user?member=${true}`);
|
|
|
|
let foundChallenge1 = _.find(challenges, { _id: challenge._id });
|
|
expect(foundChallenge1).to.not.exist;
|
|
|
|
let foundChallenge2 = _.find(challenges, { _id: challenge2._id });
|
|
expect(foundChallenge2).to.not.exist;
|
|
});
|
|
|
|
it('should return newest challenges first', async () => {
|
|
let challenges = await user.get('/challenges/user');
|
|
|
|
let foundChallengeIndex = _.findIndex(challenges, { _id: challenge2._id });
|
|
expect(foundChallengeIndex).to.eql(0);
|
|
|
|
let newChallenge = await generateChallenge(user, publicGuild);
|
|
|
|
challenges = await user.get('/challenges/user');
|
|
|
|
foundChallengeIndex = _.findIndex(challenges, { _id: newChallenge._id });
|
|
expect(foundChallengeIndex).to.eql(0);
|
|
});
|
|
|
|
it('should not return challenges user doesn\'t have access to', async () => {
|
|
let { group, groupLeader } = await createAndPopulateGroup({
|
|
groupDetails: {
|
|
name: 'TestPrivateGuild',
|
|
summary: 'summary for TestPrivateGuild',
|
|
type: 'guild',
|
|
privacy: 'private',
|
|
},
|
|
});
|
|
|
|
let privateChallenge = await generateChallenge(groupLeader, group);
|
|
|
|
let challenges = await nonMember.get('/challenges/user');
|
|
|
|
let foundChallenge = _.find(challenges, { _id: privateChallenge._id });
|
|
expect(foundChallenge).to.not.exist;
|
|
});
|
|
});
|
|
|
|
context('official challenge is present', () => {
|
|
let user, officialChallenge, challenge, challenge2, publicGuild;
|
|
|
|
before(async () => {
|
|
let { group, groupLeader } = await createAndPopulateGroup({
|
|
groupDetails: {
|
|
name: 'TestGuild',
|
|
summary: 'summary for TestGuild',
|
|
type: 'guild',
|
|
privacy: 'public',
|
|
},
|
|
});
|
|
|
|
user = groupLeader;
|
|
publicGuild = group;
|
|
|
|
await user.update({
|
|
'contributor.admin': true,
|
|
});
|
|
|
|
officialChallenge = await generateChallenge(user, group, {
|
|
official: true,
|
|
});
|
|
|
|
challenge = await generateChallenge(user, group);
|
|
challenge2 = await generateChallenge(user, group);
|
|
});
|
|
|
|
it('should return official challenges first', async () => {
|
|
let challenges = await user.get('/challenges/user');
|
|
|
|
let foundChallengeIndex = _.findIndex(challenges, { _id: officialChallenge._id });
|
|
expect(foundChallengeIndex).to.eql(0);
|
|
});
|
|
|
|
it('should return newest challenges first, after official ones', async () => {
|
|
let challenges = await user.get('/challenges/user');
|
|
|
|
let foundChallengeIndex = _.findIndex(challenges, { _id: challenge._id });
|
|
expect(foundChallengeIndex).to.eql(2);
|
|
|
|
foundChallengeIndex = _.findIndex(challenges, { _id: challenge2._id });
|
|
expect(foundChallengeIndex).to.eql(1);
|
|
|
|
let newChallenge = await generateChallenge(user, publicGuild);
|
|
|
|
challenges = await user.get('/challenges/user');
|
|
|
|
foundChallengeIndex = _.findIndex(challenges, { _id: newChallenge._id });
|
|
expect(foundChallengeIndex).to.eql(1);
|
|
});
|
|
});
|
|
});
|