mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-10-28 11:42:29 +01:00
* remove some unused dependencies * update mongoose version * make common tests pass * Make unit tests pass * make api v3 integration tests pass * fix lint issues * fix issue with package-lock * fix(lint): we don't need no .js * fix(lint): update to latest config-habitrpg * chore(npm): update package locks * fix(test): replace deprecated fn * chore(package): update eslint-habitrpg again * fix(lint): server linting * fix(lint): client linting * fix(client): correct mangled common imports * chore(npm): update package-locks * fix(lint): punctuation, module --------- Co-authored-by: SabreCat <sabrecat@gmail.com> Co-authored-by: SabreCat <sabe@habitica.com>
97 lines
3.4 KiB
JavaScript
97 lines
3.4 KiB
JavaScript
import { v4 as generateUUID } from 'uuid';
|
|
import {
|
|
createAndPopulateGroup,
|
|
translate as t,
|
|
} from '../../../../helpers/api-integration/v3';
|
|
|
|
describe('DELETE /groups/:groupId/chat/:chatId', () => {
|
|
let groupWithChat; let message; let user; let userThatDidNotCreateChat; let
|
|
admin;
|
|
|
|
before(async () => {
|
|
const { group, groupLeader, members } = await createAndPopulateGroup({
|
|
groupDetails: {
|
|
type: 'guild',
|
|
privacy: 'private',
|
|
},
|
|
leaderDetails: {
|
|
'auth.timestamps.created': new Date('2022-01-01'),
|
|
balance: 10,
|
|
},
|
|
members: 2,
|
|
upgradeToGroupPlan: true,
|
|
});
|
|
|
|
groupWithChat = group;
|
|
user = groupLeader;
|
|
message = await user.post(`/groups/${groupWithChat._id}/chat`, { message: 'Some message' });
|
|
message = message.message;
|
|
userThatDidNotCreateChat = members[0]; // eslint-disable-line prefer-destructuring
|
|
admin = members[1]; // eslint-disable-line prefer-destructuring
|
|
await admin.updateOne({ permissions: { moderator: true } });
|
|
});
|
|
|
|
context('Chat errors', () => {
|
|
it('returns an error if message does not exist', async () => {
|
|
const fakeChatId = generateUUID();
|
|
await expect(user.del(`/groups/${groupWithChat._id}/chat/${fakeChatId}`)).to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('messageGroupChatNotFound'),
|
|
});
|
|
});
|
|
|
|
it('returns an error when user does not have permission to delete', async () => {
|
|
await expect(userThatDidNotCreateChat.del(`/groups/${groupWithChat._id}/chat/${message.id}`)).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('onlyCreatorOrAdminCanDeleteChat'),
|
|
});
|
|
});
|
|
});
|
|
|
|
context('Chat success', () => {
|
|
let nextMessage;
|
|
|
|
beforeEach(async () => {
|
|
nextMessage = await user.post(`/groups/${groupWithChat._id}/chat`, { message: 'Some new message' });
|
|
nextMessage = nextMessage.message;
|
|
});
|
|
|
|
it('allows creator to delete their message', async () => {
|
|
await user.del(`/groups/${groupWithChat._id}/chat/${nextMessage.id}`);
|
|
|
|
const returnedMessages = await user.get(`/groups/${groupWithChat._id}/chat/`);
|
|
const messageFromUser = returnedMessages.find(
|
|
returnedMessage => returnedMessage.id === nextMessage.id,
|
|
);
|
|
|
|
expect(returnedMessages).is.an('array');
|
|
expect(messageFromUser).to.not.exist;
|
|
});
|
|
|
|
it('allows admin to delete another user\'s message', async () => {
|
|
await admin.del(`/groups/${groupWithChat._id}/chat/${nextMessage.id}`);
|
|
|
|
const returnedMessages = await user.get(`/groups/${groupWithChat._id}/chat/`);
|
|
const messageFromUser = returnedMessages.find(
|
|
returnedMessage => returnedMessage.id === nextMessage.id,
|
|
);
|
|
|
|
expect(returnedMessages).is.an('array');
|
|
expect(messageFromUser).to.not.exist;
|
|
});
|
|
|
|
it('returns empty when previous message parameter is passed and the last message was deleted', async () => {
|
|
await expect(user.del(`/groups/${groupWithChat._id}/chat/${nextMessage.id}?previousMsg=${nextMessage.id}`))
|
|
.to.eventually.be.empty;
|
|
});
|
|
|
|
it('returns the update chat when previous message parameter is passed and the chat is updated', async () => {
|
|
const updatedChat = await user.del(`/groups/${groupWithChat._id}/chat/${nextMessage.id}?previousMsg=${message.id}`);
|
|
|
|
expect(updatedChat[0].id).to.eql(message.id);
|
|
});
|
|
});
|
|
});
|