Rocket.Chat.ReactNative/e2e/tests/room/11-autoTranslate.spec.ts

255 lines
9.2 KiB
TypeScript
Raw Normal View History

import { by, device, element, expect, waitFor } from 'detox';
import { TTextMatcher, login, navigateToLogin, platformTypes, searchRoom, sleep, tapBack, tryTapping } from '../../helpers/app';
import { ITestUser, createRandomUser, initApi } from '../../helpers/data_setup';
import random from '../../helpers/random';
const roomId = '64b846e4760e618aa9f91ab7';
function getIndex() {
if (device.getPlatform() === 'android') {
return 1;
}
return 0;
}
const sendMessageOnTranslationTestRoom = async (msg: string): Promise<{ user: ITestUser; msgId: string }> => {
const user = await createRandomUser();
const api = await initApi(user.username, user.password);
const msgId = random();
await api.post('channels.join', { roomId, joinCode: null });
await api.post('chat.sendMessage', {
message: { _id: msgId, rid: roomId, msg, tshow: false }
});
return { user, msgId };
};
const deleteMessageOnTranslationTestRoom = async ({ user, msgId }: { user: ITestUser; msgId: string }): Promise<void> => {
const api = await initApi(user.username, user.password);
await api.post('chat.delete', {
msgId,
roomId
});
};
async function navigateToRoom(roomName: string) {
await searchRoom(`${roomName}`);
await element(by.id(`rooms-list-view-item-${roomName}`)).tap();
await waitFor(element(by.id('room-view')))
.toBeVisible()
.withTimeout(5000);
}
async function searchMessage(msg: string, textMatcher: TTextMatcher) {
await sleep(1000); // wait for proper load the room
await element(by.id('room-view-search')).tap();
await waitFor(element(by.id('search-messages-view')))
.toExist()
.withTimeout(5000);
await element(by.id('search-message-view-input')).replaceText(msg);
await waitFor(element(by[textMatcher](msg)).atIndex(getIndex()))
.toExist()
.withTimeout(30000);
await sleep(1000);
await element(by[textMatcher](msg)).atIndex(getIndex()).tap();
await sleep(10000);
}
export function waitForVisible(id: string) {
return waitFor(element(by.id(id)))
.toBeVisible()
.withTimeout(10000);
}
export function waitForVisibleTextMatcher(msg: string, textMatcher: TTextMatcher) {
return waitFor(element(by[textMatcher](msg)).atIndex(0))
.toExist()
.withTimeout(10000);
}
export function waitForNotVisible(id: string) {
return waitFor(element(by.id(id)))
.not.toBeVisible()
.withTimeout(10000);
}
describe('Auto Translate', () => {
let textMatcher: TTextMatcher;
const languages = {
default: 'en',
translated: 'pt'
};
const oldMessage = {
[languages.default]: 'dog',
[languages.translated]: 'cachorro'
};
const newMessage = {
[languages.default]: 'Cat',
[languages.translated]: 'Gato'
};
const attachmentMessage = {
[languages.default]: 'attachment',
[languages.translated]: 'anexo'
};
beforeAll(async () => {
const user = await createRandomUser();
await device.launchApp({ permissions: { notifications: 'YES' }, delete: true });
({ textMatcher } = platformTypes[device.getPlatform()]);
await navigateToLogin();
await login(user.username, user.password);
});
it('should join translation-test room', async () => {
await navigateToRoom('translation-test');
await element(by.id('room-view-join-button')).tap();
await waitForNotVisible('room-view-join-button');
await tapBack();
await navigateToRoom('translation-test');
await waitForVisible('messagebox');
await expect(element(by.id('room-view-join'))).not.toBeVisible();
});
it('should see old message not translated before enable auto translate', async () => {
await searchMessage(oldMessage[languages.default] as string, textMatcher);
await waitForVisibleTextMatcher(oldMessage[languages.default] as string, textMatcher);
await waitForVisibleTextMatcher(attachmentMessage[languages.default] as string, textMatcher);
});
it('should enable auto translate', async () => {
await element(by.id('room-header')).tap();
await waitForVisible('room-actions-view');
await element(by.id('room-actions-view')).swipe('up');
await waitForVisible('room-actions-auto-translate');
await element(by.id('room-actions-auto-translate')).tap();
await waitForVisible('auto-translate-view-switch');
await element(by.id('auto-translate-view-switch')).tap();
// verify default language is checked
await waitFor(element(by.id(`auto-translate-view-${languages.default}`)))
.toExist()
.whileElement(by.id('auto-translate-view'))
.scroll(750, 'down');
await element(by.id('auto-translate-view')).swipe('up', 'slow', 0.5);
await waitForVisible(`auto-translate-view-${languages.default}-check`);
// enable translated language
await waitFor(element(by.id(`auto-translate-view-${languages.translated}`)))
.toBeVisible()
.whileElement(by.id('auto-translate-view'))
.scroll(750, 'down');
await waitForNotVisible(`auto-translate-view-${languages.translated}-check`);
await element(by.id(`auto-translate-view-${languages.translated}`)).tap();
await waitForVisible(`auto-translate-view-${languages.translated}-check`);
// verify default language is unchecked
await waitFor(element(by.id(`auto-translate-view-${languages.default}`)))
.toBeVisible()
.whileElement(by.id('auto-translate-view'))
.scroll(750, 'up');
await waitForNotVisible(`auto-translate-view-${languages.default}-check`);
await tapBack();
await tapBack();
});
it('should see old message translated after enable auto translate', async () => {
await searchMessage(oldMessage[languages.default] as string, textMatcher);
await waitForVisibleTextMatcher(oldMessage[languages.translated] as string, textMatcher);
await waitForVisibleTextMatcher(attachmentMessage[languages.translated] as string, textMatcher);
});
it('should see new message translated', async () => {
const randomMatcher = random();
const data = await sendMessageOnTranslationTestRoom(`${newMessage[languages.default]}. Rc${randomMatcher}`);
await searchMessage(`${newMessage[languages.default]}. Rc${randomMatcher}`, textMatcher); // will scroll the messages list to the last one
await waitForVisibleTextMatcher(`${newMessage[languages.translated]}. Rc${randomMatcher}`, textMatcher);
await deleteMessageOnTranslationTestRoom(data);
});
it('should see original message', async () => {
const randomMatcher = random();
const data = await sendMessageOnTranslationTestRoom(`${newMessage[languages.default]}. Rc${randomMatcher}`);
await waitForVisibleTextMatcher(`${newMessage[languages.translated]}. Rc${randomMatcher}`, textMatcher);
await tryTapping(element(by[textMatcher](`${newMessage[languages.translated]}. Rc${randomMatcher}`)).atIndex(0), 2000, true);
await waitForVisible('action-sheet-handle');
await element(by.id('action-sheet-handle')).swipe('up', 'fast', 0.5);
await element(by[textMatcher]('Edit')).atIndex(0).swipe('up', 'fast', 0.5);
await waitForVisibleTextMatcher('View original', textMatcher);
await element(by[textMatcher]('View original')).atIndex(0).tap();
await waitForVisibleTextMatcher(`${newMessage[languages.default]}. Rc${randomMatcher}`, textMatcher);
await deleteMessageOnTranslationTestRoom(data);
});
it('disable auto translate and see original message', async () => {
const randomMatcher = random();
const data = await sendMessageOnTranslationTestRoom(`${newMessage[languages.default]}. Rc${randomMatcher}`);
await waitForVisibleTextMatcher(`${newMessage[languages.translated]}. Rc${randomMatcher}`, textMatcher);
await element(by.id('room-header')).tap();
await waitForVisible('room-actions-view');
await element(by.id('room-actions-view')).swipe('up');
await waitForVisible('room-actions-auto-translate');
await element(by.id('room-actions-auto-translate')).tap();
await waitForVisible('auto-translate-view-switch');
await element(by.id('auto-translate-view-switch')).tap();
await tapBack();
await tapBack();
await waitForVisibleTextMatcher(`${newMessage[languages.default]}. Rc${randomMatcher}`, textMatcher);
await deleteMessageOnTranslationTestRoom(data);
});
it(`should don't see action to View original when disable auto translate`, async () => {
await searchMessage(oldMessage[languages.default] as string, textMatcher); // will scroll the messages list to the last one
await waitForVisibleTextMatcher(oldMessage[languages.default] as string, textMatcher);
await tryTapping(element(by[textMatcher](oldMessage[languages.default] as string)).atIndex(0), 2000, true);
await waitForVisible('action-sheet-handle');
await element(by.id('action-sheet-handle')).swipe('up', 'fast', 0.5);
await waitForNotVisible('View original');
// close action sheet
await element(by.id('room-header')).tap();
});
it('should the language selected when activating auto translate again must be the old one', async () => {
await element(by.id('room-header')).tap();
await waitForVisible('room-actions-view');
await element(by.id('room-actions-view')).swipe('up');
await waitForVisible('room-actions-auto-translate');
await element(by.id('room-actions-auto-translate')).tap();
await waitForVisible('auto-translate-view-switch');
await element(by.id('auto-translate-view-switch')).tap();
// verify translated language is checked and is the old one
await waitFor(element(by.id(`auto-translate-view-${languages.translated}`)))
.toBeVisible()
.whileElement(by.id('auto-translate-view'))
.scroll(750, 'down');
await waitForVisible(`auto-translate-view-${languages.translated}-check`);
});
});