import data from '../../data'; import { tapBack, checkServer, navigateToRegister, platformTypes, TTextMatcher } from '../../helpers/app'; import { get, login, sendMessage } from '../../helpers/data_setup'; const DEEPLINK_METHODS = { AUTH: 'auth', ROOM: 'room' }; let amp = '&'; const getDeepLink = (method: string, server: string, params?: string) => { const deeplink = `rocketchat://${method}?host=${server.replace(/^(http:\/\/|https:\/\/)/, '')}${amp}${params}`; console.log(`Deeplinking to: ${deeplink}`); return deeplink; }; describe('Deep linking', () => { let userId: string; let authToken: string; let scrollViewType: string; let threadId: string; let textMatcher: TTextMatcher; const threadMessage = `to-thread-${data.random}`; before(async () => { const loginResult = await login(data.users.regular.username, data.users.regular.password); ({ userId, authToken } = loginResult); const deviceType = device.getPlatform(); amp = deviceType === 'android' ? '\\&' : '&'; ({ scrollViewType, textMatcher } = platformTypes[deviceType]); // create a thread with api const result = await sendMessage(data.users.regular, data.groups.alternate2.name, threadMessage); threadId = result.message._id; await sendMessage(data.users.regular, result.message.rid, data.random, threadId); }); describe('Authentication', () => { it('should run a deep link to an invalid account and raise error', async () => { await device.launchApp({ permissions: { notifications: 'YES' }, delete: true, url: getDeepLink(DEEPLINK_METHODS.AUTH, data.server, `userId=123${amp}token=abc`) }); await waitFor(element(by[textMatcher]("You've been logged out by the server. Please log in again."))) .toExist() .withTimeout(30000); // TODO: we need to improve this message }); const authAndNavigate = async () => { await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, url: getDeepLink( DEEPLINK_METHODS.AUTH, data.server, `userId=${userId}${amp}token=${authToken}${amp}path=group/${data.groups.private.name}` ) }); await waitFor(element(by.id(`room-view-title-${data.groups.private.name}`))) .toExist() .withTimeout(30000); await tapBack(); await waitFor(element(by.id('rooms-list-view'))) .toBeVisible() .withTimeout(10000); await checkServer(data.server); await waitFor(element(by.id(`rooms-list-view-item-${data.groups.private.name}`))) .toExist() .withTimeout(2000); }; it('should authenticate and navigate', async () => { await authAndNavigate(); }); it('should authenticate while logged in another server', async () => { await device.launchApp({ permissions: { notifications: 'YES' }, delete: true }); await navigateToRegister(data.alternateServer); await element(by.id('register-view-name')).replaceText(data.registeringUser4.username); await element(by.id('register-view-username')).replaceText(data.registeringUser4.username); await element(by.id('register-view-email')).replaceText(data.registeringUser4.email); await element(by.id('register-view-password')).replaceText(data.registeringUser4.password); await element(by.type(scrollViewType)).atIndex(0).scrollTo('bottom'); await element(by.id('register-view-submit')).tap(); await waitFor(element(by.id('rooms-list-view'))) .toBeVisible() .withTimeout(10000); await authAndNavigate(); }); }); describe('Room', () => { describe('While logged in', () => { it('should navigate to the room using path', async () => { await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, url: getDeepLink(DEEPLINK_METHODS.ROOM, data.server, `path=group/${data.groups.private.name}`) }); await waitFor(element(by.id(`room-view-title-${data.groups.private.name}`))) .toExist() .withTimeout(30000); }); it('should navigate to the thread using path', async () => { await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, url: getDeepLink(DEEPLINK_METHODS.ROOM, data.server, `path=group/${data.groups.alternate2.name}/thread/${threadId}`) }); await waitFor(element(by.id(`room-view-title-${threadMessage}`))) .toExist() .withTimeout(30000); }); it('should navigate to the room using rid', async () => { const roomResult = await get(`groups.info?roomName=${data.groups.private.name}`); await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, url: getDeepLink(DEEPLINK_METHODS.ROOM, data.server, `rid=${roomResult.data.group._id}`) }); await waitFor(element(by.id(`room-view-title-${data.groups.private.name}`))) .toExist() .withTimeout(30000); await tapBack(); await waitFor(element(by.id('rooms-list-view'))) .toBeVisible() .withTimeout(2000); }); it('should resume from background and navigate to the room', async () => { await device.sendToHome(); await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: false, url: getDeepLink(DEEPLINK_METHODS.ROOM, data.server, `path=group/${data.groups.private.name}`) }); await waitFor(element(by.id(`room-view-title-${data.groups.private.name}`))) .toExist() .withTimeout(30000); await tapBack(); await waitFor(element(by.id('rooms-list-view'))) .toBeVisible() .withTimeout(2000); }); }); describe('Others', () => { it('should change server', async () => { await waitFor(element(by.id('rooms-list-view'))) .toBeVisible() .withTimeout(2000); await element(by.id('rooms-list-header-server-dropdown-button')).tap(); await waitFor(element(by.id('rooms-list-header-server-dropdown'))) .toBeVisible() .withTimeout(5000); await element(by.id(`rooms-list-header-server-${data.alternateServer}`)).tap(); await checkServer(data.alternateServer); await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, url: getDeepLink(DEEPLINK_METHODS.ROOM, data.server, `path=group/${data.groups.private.name}`) }); await waitFor(element(by.id(`room-view-title-${data.groups.private.name}`))) .toExist() .withTimeout(30000); }); it('should add a not existing server and fallback to the previous one', async () => { await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, url: getDeepLink(DEEPLINK_METHODS.ROOM, 'https://google.com') }); await waitFor(element(by.id('rooms-list-view'))) .toBeVisible() .withTimeout(30000); await checkServer(data.server); }); }); }); });