mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 22:57:21 +01:00
* Strip markdown from push notifications
* Revert "Strip markdown from push notifications"
This reverts commit 4741e584c6.
* correctly set type for mention push notifications
* Add unformattedText field to chat messages
* fiix lint errors
* Add check that markdown formatting is stripped from messages
* Add check for markdown formatting in messages.
233 lines
8.2 KiB
JavaScript
233 lines
8.2 KiB
JavaScript
import { v4 as generateUUID } from 'uuid';
|
|
import {
|
|
generateUser,
|
|
translate as t,
|
|
} from '../../../../helpers/api-integration/v3';
|
|
|
|
describe('POST /members/send-private-message', () => {
|
|
let userToSendMessage;
|
|
const messageToSend = 'Test *Private* Message';
|
|
const unformattedMessage = 'Test Private Message';
|
|
|
|
beforeEach(async () => {
|
|
userToSendMessage = await generateUser();
|
|
});
|
|
|
|
it('returns error when message is not provided', async () => {
|
|
await expect(userToSendMessage.post('/members/send-private-message'))
|
|
.to.eventually.be.rejected.and.eql({
|
|
code: 400,
|
|
error: 'BadRequest',
|
|
message: 'Invalid request parameters.',
|
|
});
|
|
});
|
|
|
|
it('returns error when toUserId is not provided', async () => {
|
|
await expect(userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 400,
|
|
error: 'BadRequest',
|
|
message: 'Invalid request parameters.',
|
|
});
|
|
});
|
|
|
|
it('returns error when to user is not found', async () => {
|
|
await expect(userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: generateUUID(),
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 404,
|
|
error: 'NotFound',
|
|
message: t('userNotFound'),
|
|
});
|
|
});
|
|
|
|
it('returns error when to user has blocked the sender', async () => {
|
|
const receiver = await generateUser({ 'inbox.blocks': [userToSendMessage._id] });
|
|
|
|
await expect(userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('notAuthorizedToSendMessageToThisUser'),
|
|
});
|
|
});
|
|
|
|
it('returns error when sender has blocked to user', async () => {
|
|
const receiver = await generateUser();
|
|
const sender = await generateUser({ 'inbox.blocks': [receiver._id] });
|
|
|
|
await expect(sender.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('notAuthorizedToSendMessageToThisUser'),
|
|
});
|
|
});
|
|
|
|
it('returns error when to user has opted out of messaging', async () => {
|
|
const receiver = await generateUser({ 'inbox.optOut': true });
|
|
|
|
await expect(userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('notAuthorizedToSendMessageToThisUser'),
|
|
});
|
|
});
|
|
|
|
it('returns an error when chat privileges are revoked', async () => {
|
|
const userWithChatRevoked = await generateUser({ 'flags.chatRevoked': true });
|
|
const receiver = await generateUser();
|
|
|
|
await expect(userWithChatRevoked.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 401,
|
|
error: 'NotAuthorized',
|
|
message: t('chatPrivilegesRevoked'),
|
|
});
|
|
});
|
|
|
|
it('sends a private message to a user', async () => {
|
|
const receiver = await generateUser();
|
|
// const initialNotifications = receiver.notifications.length;
|
|
|
|
const response = await userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
});
|
|
|
|
const updatedReceiver = await receiver.get('/user');
|
|
const updatedSender = await userToSendMessage.get('/user');
|
|
|
|
const sendersMessageInReceiversInbox = _.find(
|
|
updatedReceiver.inbox.messages,
|
|
message => message.uuid === userToSendMessage._id
|
|
&& message.text === messageToSend
|
|
&& message.unformattedText === unformattedMessage,
|
|
);
|
|
|
|
const sendersMessageInSendersInbox = _.find(
|
|
updatedSender.inbox.messages,
|
|
message => message.uuid === receiver._id && message.text === messageToSend,
|
|
);
|
|
|
|
expect(response.message.text).to.deep.equal(sendersMessageInSendersInbox.text);
|
|
expect(response.message.uuid).to.deep.equal(sendersMessageInSendersInbox.uuid);
|
|
|
|
// @TODO waiting for mobile support
|
|
// expect(updatedReceiver.notifications.length).to.equal(initialNotifications + 1);
|
|
// const notification = updatedReceiver.notifications[updatedReceiver.notifications.length - 1];
|
|
|
|
// expect(notification.type).to.equal('NEW_INBOX_MESSAGE');
|
|
// expect(notification.data.messageId).to.equal(sendersMessageInReceiversInbox.id);
|
|
// expect(notification.data.excerpt).to.equal(messageToSend);
|
|
// expect(notification.data.sender.id).to.equal(updatedSender._id);
|
|
// expect(notification.data.sender.name).to.equal(updatedSender.profile.name);
|
|
|
|
expect(sendersMessageInReceiversInbox).to.exist;
|
|
expect(sendersMessageInSendersInbox).to.exist;
|
|
});
|
|
|
|
it('sends a private message with mentions to a user', async () => {
|
|
const receiver = await generateUser();
|
|
|
|
const response = await userToSendMessage.post('/members/send-private-message', {
|
|
message: `hi @${receiver.auth.local.username}`,
|
|
toUserId: receiver._id,
|
|
});
|
|
|
|
expect(response.message.text).to.include(`[@${receiver.auth.local.username}](/profile/${receiver._id})`);
|
|
});
|
|
|
|
// @TODO waiting for mobile support
|
|
xit('creates a notification with an excerpt if the message is too long', async () => {
|
|
const receiver = await generateUser();
|
|
const longerMessageToSend = 'A very long message, that for sure exceeds the limit of 100 chars for the excerpt that we set to 100 chars';
|
|
const messageExcerpt = `${longerMessageToSend.substring(0, 100)}...`;
|
|
|
|
await userToSendMessage.post('/members/send-private-message', {
|
|
message: longerMessageToSend,
|
|
toUserId: receiver._id,
|
|
});
|
|
|
|
const updatedReceiver = await receiver.get('/user');
|
|
|
|
const sendersMessageInReceiversInbox = _.find(
|
|
updatedReceiver.inbox.messages,
|
|
message => message.uuid === userToSendMessage._id && message.text === longerMessageToSend,
|
|
);
|
|
|
|
const notification = updatedReceiver.notifications[updatedReceiver.notifications.length - 1];
|
|
|
|
expect(notification.type).to.equal('NEW_INBOX_MESSAGE');
|
|
expect(notification.data.messageId).to.equal(sendersMessageInReceiversInbox.id);
|
|
expect(notification.data.excerpt).to.equal(messageExcerpt);
|
|
});
|
|
|
|
it('allows admin to send when sender has blocked the admin', async () => {
|
|
userToSendMessage = await generateUser({
|
|
'contributor.admin': 1,
|
|
});
|
|
const receiver = await generateUser({ 'inbox.blocks': [userToSendMessage._id] });
|
|
|
|
await userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
});
|
|
|
|
const updatedReceiver = await receiver.get('/user');
|
|
const updatedSender = await userToSendMessage.get('/user');
|
|
|
|
const sendersMessageInReceiversInbox = _.find(
|
|
updatedReceiver.inbox.messages,
|
|
message => message.uuid === userToSendMessage._id && message.text === messageToSend,
|
|
);
|
|
|
|
const sendersMessageInSendersInbox = _.find(
|
|
updatedSender.inbox.messages,
|
|
message => message.uuid === receiver._id && message.text === messageToSend,
|
|
);
|
|
|
|
expect(sendersMessageInReceiversInbox).to.exist;
|
|
expect(sendersMessageInSendersInbox).to.exist;
|
|
});
|
|
|
|
it('allows admin to send when to user has opted out of messaging', async () => {
|
|
userToSendMessage = await generateUser({
|
|
'contributor.admin': 1,
|
|
});
|
|
const receiver = await generateUser({ 'inbox.optOut': true });
|
|
|
|
await userToSendMessage.post('/members/send-private-message', {
|
|
message: messageToSend,
|
|
toUserId: receiver._id,
|
|
});
|
|
|
|
const updatedReceiver = await receiver.get('/user');
|
|
const updatedSender = await userToSendMessage.get('/user');
|
|
|
|
const sendersMessageInReceiversInbox = _.find(
|
|
updatedReceiver.inbox.messages,
|
|
message => message.uuid === userToSendMessage._id && message.text === messageToSend,
|
|
);
|
|
|
|
const sendersMessageInSendersInbox = _.find(
|
|
updatedSender.inbox.messages,
|
|
message => message.uuid === receiver._id && message.text === messageToSend,
|
|
);
|
|
|
|
expect(sendersMessageInReceiversInbox).to.exist;
|
|
expect(sendersMessageInSendersInbox).to.exist;
|
|
});
|
|
});
|