mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-15 13:47:33 +01:00
* shared model for chat and inbox * disable inbox schema * inbox: use separate model * remove old code that used group.chat * add back chat field (not used) and remove old tests * remove inbox exclusions when loading user * add GET /api/v3/inbox/messages * add comment * implement DELETE /inbox/messages/:messageid in v4 * implement GET /inbox/messages in v4 and update tests * implement DELETE /api/v4/inbox/clear * fix url * fix doc * update /export/inbox.html * update other data exports * add back messages in user schema * add user.toJSONWithInbox * add compativility until migration is done * more compatibility * fix tojson called twice * add compatibility methods * fix common tests * fix v4 integration tests * v3 get user -> with inbox * start to fix tests * fix v3 integration tests * wip * wip, client use new route * update tests for members/send-private-message * tests for get user in v4 * add tests for DELETE /inbox/messages/:messageId * add tests for DELETE /inbox/clear in v4 * update docs * fix tests * initial migration * fix migration * fix migration * migration fixes * migrate api.enterCouponCode * migrate api.castSpell * migrate reset, reroll, rebirth * add routes to v4 version * fix tests * fixes * api.updateUser * remove .only * get user -> userLib * refactor inbox.vue to work with new data model * fix return message when messaging yourself * wip fix bug with new conversation * wip * fix remaining ui issues * move api.registerLocal, fixes * keep only v3 version of GET /inbox/messages
61 lines
1.4 KiB
JavaScript
61 lines
1.4 KiB
JavaScript
import {
|
|
generateUser,
|
|
generateDaily,
|
|
generateReward,
|
|
translate as t,
|
|
} from '../../../helpers/api-integration/v4';
|
|
|
|
describe('POST /user/rebirth', () => {
|
|
let user;
|
|
|
|
beforeEach(async () => {
|
|
user = await generateUser();
|
|
});
|
|
|
|
it('returns an error when user balance is too low', async () => {
|
|
await expect(user.post('/user/rebirth'))
|
|
.to.eventually.be.rejected.and.to.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('notEnoughGems'),
|
|
});
|
|
});
|
|
|
|
// More tests in common code unit tests
|
|
|
|
it('resets user\'s tasks', async () => {
|
|
await user.update({
|
|
balance: 1.5,
|
|
});
|
|
|
|
let daily = await generateDaily({
|
|
text: 'test habit',
|
|
type: 'daily',
|
|
value: 1,
|
|
streak: 1,
|
|
userId: user._id,
|
|
});
|
|
|
|
let reward = await generateReward({
|
|
text: 'test reward',
|
|
type: 'reward',
|
|
value: 1,
|
|
userId: user._id,
|
|
});
|
|
|
|
let response = await user.post('/user/rebirth');
|
|
await user.sync();
|
|
|
|
expect(user.notifications.length).to.equal(1);
|
|
expect(user.notifications[0].type).to.equal('REBIRTH_ACHIEVEMENT');
|
|
|
|
let updatedDaily = await user.get(`/tasks/${daily._id}`);
|
|
let updatedReward = await user.get(`/tasks/${reward._id}`);
|
|
|
|
expect(response.message).to.equal(t('rebirthComplete'));
|
|
expect(updatedDaily.streak).to.equal(0);
|
|
expect(updatedDaily.value).to.equal(0);
|
|
expect(updatedReward.value).to.equal(1);
|
|
});
|
|
});
|