mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 13:17:24 +01:00
* Allowing the flagging of messages that were written by user accounts that have since been deleted * replacing ternary operator with else if, else paradigm * formatting fixes * fixing message in tests
99 lines
3.5 KiB
JavaScript
99 lines
3.5 KiB
JavaScript
import {
|
|
generateUser,
|
|
translate as t,
|
|
} from '../../../../helpers/api-v3-integration.helper';
|
|
import { find } from 'lodash';
|
|
|
|
describe('POST /chat/:chatId/flag', () => {
|
|
let user, admin, anotherUser, group;
|
|
const TEST_MESSAGE = 'Test Message';
|
|
|
|
before(async () => {
|
|
user = await generateUser({balance: 1});
|
|
admin = await generateUser({balance: 1, 'contributor.admin': true});
|
|
anotherUser = await generateUser();
|
|
|
|
group = await user.post('/groups', {
|
|
name: 'Test Guild',
|
|
type: 'guild',
|
|
privacy: 'public',
|
|
});
|
|
});
|
|
|
|
it('Returns an error when chat message is not found', async () => {
|
|
await expect(user.post(`/groups/${group._id}/chat/incorrectMessage/flag`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('messageGroupChatNotFound'),
|
|
});
|
|
});
|
|
|
|
it('Returns an error when user tries to flag their own message', async () => {
|
|
let message = await user.post(`/groups/${group._id}/chat`, {message: TEST_MESSAGE});
|
|
await expect(user.post(`/groups/${group._id}/chat/${message.message.id}/flag`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('messageGroupChatFlagOwnMessage'),
|
|
});
|
|
});
|
|
|
|
it('Flags a chat', async () => {
|
|
let { message } = await anotherUser.post(`/groups/${group._id}/chat`, {message: TEST_MESSAGE});
|
|
|
|
let flagResult = await user.post(`/groups/${group._id}/chat/${message.id}/flag`);
|
|
expect(flagResult.flags[user._id]).to.equal(true);
|
|
expect(flagResult.flagCount).to.equal(1);
|
|
|
|
let groupWithFlags = await admin.get(`/groups/${group._id}`);
|
|
|
|
let messageToCheck = find(groupWithFlags.chat, {id: message.id});
|
|
expect(messageToCheck.flags[user._id]).to.equal(true);
|
|
});
|
|
|
|
it('Flags a chat when the author\'s account was deleted', async () => {
|
|
let deletedUser = await generateUser();
|
|
let { message } = await deletedUser.post(`/groups/${group._id}/chat`, {message: TEST_MESSAGE});
|
|
await deletedUser.del('/user', {
|
|
password: 'password',
|
|
});
|
|
|
|
let flagResult = await user.post(`/groups/${group._id}/chat/${message.id}/flag`);
|
|
expect(flagResult.flags[user._id]).to.equal(true);
|
|
expect(flagResult.flagCount).to.equal(1);
|
|
|
|
let groupWithFlags = await admin.get(`/groups/${group._id}`);
|
|
|
|
let messageToCheck = find(groupWithFlags.chat, {id: message.id});
|
|
expect(messageToCheck.flags[user._id]).to.equal(true);
|
|
});
|
|
|
|
it('Flags a chat with a higher flag acount when an admin flags the message', async () => {
|
|
let { message } = await user.post(`/groups/${group._id}/chat`, {message: TEST_MESSAGE});
|
|
|
|
let flagResult = await admin.post(`/groups/${group._id}/chat/${message.id}/flag`);
|
|
expect(flagResult.flags[admin._id]).to.equal(true);
|
|
expect(flagResult.flagCount).to.equal(5);
|
|
|
|
let groupWithFlags = await admin.get(`/groups/${group._id}`);
|
|
|
|
let messageToCheck = find(groupWithFlags.chat, {id: message.id});
|
|
expect(messageToCheck.flags[admin._id]).to.equal(true);
|
|
expect(messageToCheck.flagCount).to.equal(5);
|
|
});
|
|
|
|
it('Returns an error when user tries to flag a message that is already flagged', async () => {
|
|
let { message } = await anotherUser.post(`/groups/${group._id}/chat`, {message: TEST_MESSAGE});
|
|
|
|
await user.post(`/groups/${group._id}/chat/${message.id}/flag`);
|
|
|
|
await expect(user.post(`/groups/${group._id}/chat/${message.id}/flag`))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('messageGroupChatFlagAlreadyReported'),
|
|
});
|
|
});
|
|
});
|