Files
mattermost-mobile/detox/e2e/test/messaging/message_draft.e2e.ts
2023-02-09 09:40:32 +01:00

191 lines
7.8 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
// *******************************************************************
// - [#] indicates a test step (e.g. # Go to a screen)
// - [*] indicates an assertion (e.g. * Check the title)
// - Use element testID when selecting an element. Create one if none.
// *******************************************************************
import {
Post,
Setup,
} from '@support/server_api';
import {
serverOneUrl,
siteOneUrl,
} from '@support/test_config';
import {Alert} from '@support/ui/component';
import {
ChannelScreen,
ChannelListScreen,
HomeScreen,
LoginScreen,
ServerScreen,
ThreadScreen,
} from '@support/ui/screen';
import {getRandomId, isIos} from '@support/utils';
import {expect} from 'detox';
describe('Messaging - Message Draft', () => {
const serverOneDisplayName = 'Server 1';
const channelsCategory = 'channels';
const offTopicChannelName = 'off-topic';
let testChannel: any;
beforeAll(async () => {
const {channel, user} = await Setup.apiInit(siteOneUrl);
testChannel = channel;
// # Log in to server
await ServerScreen.connectToServer(serverOneUrl, serverOneDisplayName);
await LoginScreen.login(user);
});
beforeEach(async () => {
// * Verify on channel list screen
await ChannelListScreen.toBeVisible();
});
afterAll(async () => {
// # Log out
await HomeScreen.logout();
});
it('MM-T4781_1 - should be able to create a message draft', async () => {
// # Open a channel screen and create a message draft
const message = `Message ${getRandomId()}`;
await ChannelScreen.open(channelsCategory, testChannel.name);
await ChannelScreen.postInput.tap();
await ChannelScreen.postInput.replaceText(message);
// * Verify message exists in post draft and is not yet added to post list
if (isIos()) {
await expect(ChannelScreen.postInput).toHaveValue(message);
} else {
await expect(ChannelScreen.postInput).toHaveText(message);
}
const {post} = await Post.apiGetLastPostInChannel(siteOneUrl, testChannel.id);
const {postListPostItem} = ChannelScreen.getPostListPostItem(post.id, message);
await expect(postListPostItem).not.toExist();
// # Switch to another channel and go back to original channel
await ChannelScreen.back();
await ChannelScreen.open(channelsCategory, offTopicChannelName);
await ChannelScreen.back();
await ChannelScreen.open(channelsCategory, testChannel.name);
// * Verify message draft still exists in post draft
if (isIos()) {
await expect(ChannelScreen.postInput).toHaveValue(message);
} else {
await expect(ChannelScreen.postInput).toHaveText(message);
}
// # Clear post draft and go back to channel list screen
await ChannelScreen.postInput.clearText();
await ChannelScreen.back();
});
it('MM-T4781_2 - should save message draft when app is closed then re-opened', async () => {
// # Open a channel screen and create a message draft
const message = `Message ${getRandomId()}`;
await ChannelScreen.open(channelsCategory, testChannel.name);
await ChannelScreen.postInput.tap();
await ChannelScreen.postInput.replaceText(message);
// * Verify message draft exists in post draft
if (isIos()) {
await expect(ChannelScreen.postInput).toHaveValue(message);
} else {
await expect(ChannelScreen.postInput).toHaveText(message);
}
// # Send app to home and re-open
await device.sendToHome();
await device.launchApp({newInstance: false});
// * Verify message draft still exists in post draft
if (isIos()) {
await expect(ChannelScreen.postInput).toHaveValue(message);
} else {
await expect(ChannelScreen.postInput).toHaveText(message);
}
// # Clear post draft and go back to channel list screen
await ChannelScreen.postInput.clearText();
await ChannelScreen.back();
});
it('MM-T4781_3 - should show character count warning when message exceeds character limit', async () => {
// # Open a channel screen and create a message draft that exceeds character limit (> 16383)
let message = '1234567890'.repeat(1638) + '1234';
await ChannelScreen.open(channelsCategory, testChannel.name);
await ChannelScreen.postInput.tap();
await ChannelScreen.postInput.replaceText(message);
// * Verify warning message is displayed and send button is disabled
await expect(Alert.messageLengthTitle).toBeVisible();
await expect(element(by.text('Your current message is too long. Current character count: 16384/16383'))).toBeVisible();
await Alert.okButton.tap();
await expect(ChannelScreen.sendButtonDisabled).toBeVisible();
// # Replace message draft with length less than the character limit (16383)
message = '1234567890'.repeat(1638) + '123';
await ChannelScreen.postInput.replaceText(message);
// * Verify warning message is not displayed and send button is enabled
await expect(Alert.messageLengthTitle).not.toBeVisible();
await expect(element(by.text('Your current message is too long. Current character count: 16383/16383'))).not.toBeVisible();
await expect(ChannelScreen.sendButton).toBeVisible();
// # Clear post draft and go back to channel list screen
await ChannelScreen.postInput.clearText();
await ChannelScreen.back();
});
it('MM-T4781_4 - should be able to create a message draft from reply thread -- KNOWN ISSUE: MM-50298', async () => {
// # Open a channel screen, post a message, and tap on the post to open reply thread
const message = `Message ${getRandomId()}`;
await ChannelScreen.open(channelsCategory, testChannel.name);
await ChannelScreen.postMessage(message);
const {post: parentPost} = await Post.apiGetLastPostInChannel(siteOneUrl, testChannel.id);
const {postListPostItem: parentPostListPostItem} = ChannelScreen.getPostListPostItem(parentPost.id, message);
await parentPostListPostItem.tap();
// * Verify on thread screen
await ThreadScreen.toBeVisible();
// # Create a reply message draft
const replyMessage = `${message} reply`;
await ThreadScreen.postInput.tap();
await ThreadScreen.postInput.replaceText(replyMessage);
// * Verify reply message exists in post draft and is not yet added to post list
if (isIos()) {
await expect(ThreadScreen.postInput).toHaveValue(replyMessage);
} else {
await expect(ThreadScreen.postInput).toHaveText(replyMessage);
}
const {post} = await Post.apiGetLastPostInChannel(siteOneUrl, testChannel.id);
const {postListPostItem: replyPostListPostItem} = ThreadScreen.getPostListPostItem(post.id, replyMessage);
await expect(replyPostListPostItem).not.toExist();
// # Go back to channel screen and tap on parent post again
await ThreadScreen.back();
await parentPostListPostItem.tap();
// * Verify reply message draft still exists in post draft
if (isIos()) {
await expect(ThreadScreen.postInput).toHaveValue(replyMessage);
} else {
await expect(ThreadScreen.postInput).toHaveText(replyMessage);
}
// # Clear reply post draft and go back to channel list screen
await ThreadScreen.postInput.clearText();
await ThreadScreen.back();
await ChannelScreen.back();
});
});