mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-19 07:37:25 +01:00
Moved unlinkChallengeTasks to challenge model and added tests
This commit is contained in:
@@ -122,6 +122,33 @@ describe('Challenge Model', () => {
|
|||||||
|
|
||||||
expect(updatedUserTask.challenge.broken).to.equal('TASK_DELETED');
|
expect(updatedUserTask.challenge.broken).to.equal('TASK_DELETED');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('unlinks and deletes challenge tasks for a user when remove-all is specified', async () => {
|
||||||
|
await challenge.addTasks([task]);
|
||||||
|
await challenge.unlinkTasks(leader, 'remove-all');
|
||||||
|
|
||||||
|
let updatedLeader = await User.findOne({_id: leader._id});
|
||||||
|
let updatedLeadersTasks = await Tasks.Task.find({_id: { $in: updatedLeader.tasksOrder[`${taskType}s`]}});
|
||||||
|
let syncedTask = find(updatedLeadersTasks, function findNewTask (updatedLeadersTask) {
|
||||||
|
return updatedLeadersTask.type === taskValue.type && updatedLeadersTask.text === taskValue.text;
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(syncedTask).to.not.exist;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('unlinks and keeps challenge tasks for a user when keep-all is specified', async () => {
|
||||||
|
await challenge.addTasks([task]);
|
||||||
|
await challenge.unlinkTasks(leader, 'keep-all');
|
||||||
|
|
||||||
|
let updatedLeader = await User.findOne({_id: leader._id});
|
||||||
|
let updatedLeadersTasks = await Tasks.Task.find({_id: { $in: updatedLeader.tasksOrder[`${taskType}s`]}});
|
||||||
|
let syncedTask = find(updatedLeadersTasks, function findNewTask (updatedLeadersTask) {
|
||||||
|
return updatedLeadersTask.type === taskValue.type && updatedLeadersTask.text === taskValue.text;
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(syncedTask).to.exist;
|
||||||
|
expect(syncedTask.challenge._id).to.be.empty;
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -191,7 +191,7 @@ api.leaveChallenge = {
|
|||||||
challenge.memberCount -= 1;
|
challenge.memberCount -= 1;
|
||||||
|
|
||||||
// Unlink challenge's tasks from user's tasks and save the challenge
|
// Unlink challenge's tasks from user's tasks and save the challenge
|
||||||
await Q.all([user.unlinkChallengeTasks(challenge._id, keep), challenge.save()]);
|
await Q.all([challenge.unlinkTasks(user, keep), challenge.save()]);
|
||||||
res.respond(200, {});
|
res.respond(200, {});
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import baseModel from '../libs/api-v3/baseModel';
|
|||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import * as Tasks from './task';
|
import * as Tasks from './task';
|
||||||
import { model as User } from './user';
|
import { model as User } from './user';
|
||||||
|
import { removeFromArray } from '../libs/api-v3/collectionManipulators';
|
||||||
|
|
||||||
let Schema = mongoose.Schema;
|
let Schema = mongoose.Schema;
|
||||||
|
|
||||||
@@ -214,4 +215,37 @@ schema.methods.removeTask = async function challengeRemoveTask (task) {
|
|||||||
}, {multi: true}).exec();
|
}, {multi: true}).exec();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Unlink challenges tasks (and the challenge itself) from user
|
||||||
|
schema.methods.unlinkTasks = async function challengeUnlinkTasks (user, keep) {
|
||||||
|
let challengeId = this._id;
|
||||||
|
let findQuery = {
|
||||||
|
userId: user._id,
|
||||||
|
'challenge.id': challengeId,
|
||||||
|
};
|
||||||
|
|
||||||
|
removeFromArray(user.challenges, challengeId);
|
||||||
|
|
||||||
|
if (keep === 'keep-all') {
|
||||||
|
await Tasks.Task.update(findQuery, {
|
||||||
|
$set: {challenge: {}}, // TODO what about updatedAt?
|
||||||
|
}, {multi: true}).exec();
|
||||||
|
|
||||||
|
await user.save();
|
||||||
|
} else { // keep = 'remove-all'
|
||||||
|
let tasks = await Tasks.Task.find(findQuery).select('_id type completed').exec();
|
||||||
|
let taskPromises = tasks.map(task => {
|
||||||
|
// Remove task from user.tasksOrder and delete them
|
||||||
|
if (task.type !== 'todo' || !task.completed) {
|
||||||
|
removeFromArray(user.tasksOrder[`${task.type}s`], task._id);
|
||||||
|
}
|
||||||
|
|
||||||
|
return task.remove();
|
||||||
|
});
|
||||||
|
user.markModified('tasksOrder');
|
||||||
|
taskPromises.push(user.save());
|
||||||
|
return Q.all(taskPromises);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
export let model = mongoose.model('Challenge', schema);
|
export let model = mongoose.model('Challenge', schema);
|
||||||
|
|||||||
@@ -587,7 +587,7 @@ schema.methods.leave = async function leaveGroup (user, keep = 'keep-all') {
|
|||||||
});
|
});
|
||||||
|
|
||||||
let challengesToRemoveUserFrom = challenges.map(chal => {
|
let challengesToRemoveUserFrom = challenges.map(chal => {
|
||||||
return user.unlinkChallengeTasks(chal._id, keep);
|
return chal.unlinkTasks(user, keep);
|
||||||
});
|
});
|
||||||
await Q.all(challengesToRemoveUserFrom);
|
await Q.all(challengesToRemoveUserFrom);
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ import moment from 'moment';
|
|||||||
import * as Tasks from './task';
|
import * as Tasks from './task';
|
||||||
import Q from 'q';
|
import Q from 'q';
|
||||||
import { schema as TagSchema } from './tag';
|
import { schema as TagSchema } from './tag';
|
||||||
import { removeFromArray } from '../libs/api-v3/collectionManipulators';
|
|
||||||
import baseModel from '../libs/api-v3/baseModel';
|
import baseModel from '../libs/api-v3/baseModel';
|
||||||
// import {model as Challenge} from './challenge';
|
// import {model as Challenge} from './challenge';
|
||||||
|
|
||||||
@@ -696,38 +695,6 @@ schema.methods.getGroups = function getUserGroups () {
|
|||||||
return userGroups;
|
return userGroups;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Unlink challenges tasks (and the challenge itself) from user
|
|
||||||
schema.methods.unlinkChallengeTasks = async function unlinkChallengeTasks (challengeId, keep) {
|
|
||||||
let user = this;
|
|
||||||
let findQuery = {
|
|
||||||
userId: user._id,
|
|
||||||
'challenge.id': challengeId,
|
|
||||||
};
|
|
||||||
|
|
||||||
removeFromArray(user.challenges, challengeId);
|
|
||||||
|
|
||||||
if (keep === 'keep-all') {
|
|
||||||
await Tasks.Task.update(findQuery, {
|
|
||||||
$set: {challenge: {}}, // TODO what about updatedAt?
|
|
||||||
}, {multi: true}).exec();
|
|
||||||
|
|
||||||
await user.save();
|
|
||||||
} else { // keep = 'remove-all'
|
|
||||||
let tasks = await Tasks.Task.find(findQuery).select('_id type completed').exec();
|
|
||||||
let taskPromises = tasks.map(task => {
|
|
||||||
// Remove task from user.tasksOrder and delete them
|
|
||||||
if (task.type !== 'todo' || !task.completed) {
|
|
||||||
removeFromArray(user.tasksOrder[`${task.type}s`], task._id);
|
|
||||||
}
|
|
||||||
|
|
||||||
return task.remove();
|
|
||||||
});
|
|
||||||
|
|
||||||
taskPromises.push(user.save());
|
|
||||||
return Q.all(taskPromises);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export let model = mongoose.model('User', schema);
|
export let model = mongoose.model('User', schema);
|
||||||
|
|
||||||
// Initially export an empty object so external requires will get
|
// Initially export an empty object so external requires will get
|
||||||
|
|||||||
Reference in New Issue
Block a user