const { login, navigateToLogin, logout, tapBack, searchRoom } = require('../../helpers/app'); const data = require('../../data'); describe('Rooms list screen', () => { before(async() => { await device.launchApp({ permissions: { notifications: 'YES' }, newInstance: true, delete: true }); await navigateToLogin(); await login(data.users.regular.username, data.users.regular.password); }); describe('Render', () => { it('should have rooms list screen', async() => { await expect(element(by.id('rooms-list-view'))).toBeVisible(); }); it('should have room item', async() => { await expect(element(by.id('rooms-list-view-item-general'))).toExist(); }); // Render - Header describe('Header', () => { it('should have create channel button', async() => { await expect(element(by.id('rooms-list-view-create-channel'))).toBeVisible(); }); it('should have sidebar button', async() => { await expect(element(by.id('rooms-list-view-sidebar'))).toBeVisible(); }); }); }); describe('Usage', () => { it('should search room and navigate', async() => { await searchRoom('rocket.cat'); await element(by.id('rooms-list-view-item-rocket.cat')).tap(); await waitFor(element(by.id('room-view'))).toBeVisible().withTimeout(10000); await waitFor(element(by.id('room-view-title-rocket.cat'))).toBeVisible().withTimeout(60000); await tapBack(); await waitFor(element(by.id('rooms-list-view'))).toBeVisible().withTimeout(2000); await waitFor(element(by.id('rooms-list-view-item-rocket.cat'))).toExist().withTimeout(60000); }); it('should logout', async() => { await logout(); }); }); });