const { device, expect, element, by, waitFor } = require('detox'); const { takeScreenshot } = require('./helpers/screenshot'); const data = require('./data'); const { tapBack } = require('./helpers/app'); async function navigateToRoomInfo(type) { let room; if (type === 'd') { room = 'rocket.cat'; } else { room = `private${ data.random }`; } await waitFor(element(by.id(`rooms-list-view-item-${ room }`))).toBeVisible().withTimeout(2000); await element(by.id(`rooms-list-view-item-${ room }`)).tap(); await waitFor(element(by.id('room-view'))).toBeVisible().withTimeout(2000); await element(by.id('room-view-header-actions')).tap(); await waitFor(element(by.id('room-actions-view'))).toBeVisible().withTimeout(5000); await element(by.id('room-actions-info')).tap(); await waitFor(element(by.id('room-info-view'))).toBeVisible().withTimeout(2000); } describe('Room info screen', () => { describe('Direct', async() => { before(async() => { await device.reloadReactNative(); await navigateToRoomInfo('d'); }); it('should navigate to room info', async() => { await expect(element(by.id('room-info-view'))).toBeVisible(); await expect(element(by.id('room-info-view-name'))).toBeVisible(); }); after(async() => { await takeScreenshot(); }); }); describe('Channel/Group', async() => { before(async() => { await device.reloadReactNative(); await navigateToRoomInfo('c'); }); describe('Render', async() => { it('should have room info view', async() => { await expect(element(by.id('room-info-view'))).toBeVisible(); }); it('should have name', async() => { await expect(element(by.id('room-info-view-name'))).toBeVisible(); }); it('should have description', async() => { await expect(element(by.id('room-info-view-description'))).toBeVisible(); }); it('should have topic', async() => { await expect(element(by.id('room-info-view-topic'))).toBeVisible(); }); it('should have announcement', async() => { await expect(element(by.id('room-info-view-announcement'))).toBeVisible(); }); it('should have edit button', async() => { await expect(element(by.id('room-info-view-edit-button'))).toBeVisible(); }); after(async() => { takeScreenshot(); }); }); describe('Render Edit', async() => { before(async() => { await waitFor(element(by.id('room-info-view-edit-button'))).toBeVisible().withTimeout(10000); await element(by.id('room-info-view-edit-button')).tap(); await waitFor(element(by.id('room-info-edit-view'))).toBeVisible().withTimeout(2000); }); it('should have room info edit view', async() => { await expect(element(by.id('room-info-edit-view'))).toExist(); }); it('should have name input', async() => { await expect(element(by.id('room-info-edit-view-name'))).toExist(); }); it('should have description input', async() => { await expect(element(by.id('room-info-edit-view-description'))).toBeVisible(); }); it('should have topic input', async() => { await expect(element(by.id('room-info-edit-view-topic'))).toBeVisible(); }); it('should have announcement input', async() => { await expect(element(by.id('room-info-edit-view-announcement'))).toBeVisible(); }); it('should have password input', async() => { await expect(element(by.id('room-info-edit-view-password'))).toBeVisible(); }); it('should have type switch', async() => { await element(by.id('room-info-edit-view-list')).swipe('up'); await expect(element(by.id('room-info-edit-view-t'))).toBeVisible(); }); it('should have ready only switch', async() => { await expect(element(by.id('room-info-edit-view-ro'))).toBeVisible(); }); it('should have submit button', async() => { await expect(element(by.id('room-info-edit-view-submit'))).toBeVisible(); }); it('should have reset button', async() => { await expect(element(by.id('room-info-edit-view-reset'))).toBeVisible(); }); it('should have archive button', async() => { await expect(element(by.id('room-info-edit-view-archive'))).toBeVisible(); }); it('should have delete button', async() => { await expect(element(by.id('room-info-edit-view-delete'))).toBeVisible(); }); after(async() => { await takeScreenshot(); await element(by.id('room-info-edit-view-list')).swipe('down'); }); }); describe('Usage', async() => { const room = `private${ data.random }`; // it('should enter "invalid name" and get error', async() => { // await element(by.id('room-info-edit-view-list')).swipe('down'); // await element(by.id('room-info-edit-view-name')).replaceText('invalid name'); // await element(by.id('room-info-edit-view-list')).swipe('up'); // await element(by.id('room-info-edit-view-submit')).tap(); // await waitFor(element(by.text('There was an error while saving settings!'))).toBeVisible().withTimeout(60000); // await expect(element(by.text('There was an error while saving settings!'))).toBeVisible(); // await element(by.text('OK')).tap(); // await waitFor(element(by.text('There was an error while saving settings!'))).toBeNotVisible().withTimeout(10000); // await element(by.id('room-info-edit-view-list')).swipe('down'); // }); it('should change room name', async() => { await element(by.id('room-info-edit-view-name')).replaceText(`${ room }new`); await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); await tapBack('Room Info'); await waitFor(element(by.id('room-info-view'))).toBeVisible().withTimeout(2000); await waitFor(element(by.id('room-info-view-name'))).toHaveText(`${ room }new`).withTimeout(60000); await expect(element(by.id('room-info-view-name'))).toHaveText(`${ room }new`); // change name to original await element(by.id('room-info-view-edit-button')).tap(); await waitFor(element(by.id('room-info-edit-view'))).toBeVisible().withTimeout(2000); await element(by.id('room-info-edit-view-name')).replaceText(`${ room }`); await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); await element(by.id('room-info-edit-view-list')).swipe('down'); }); it('should reset form', async() => { await element(by.id('room-info-edit-view-name')).replaceText('abc'); await element(by.id('room-info-edit-view-description')).replaceText('abc'); await element(by.id('room-info-edit-view-topic')).replaceText('abc'); await element(by.id('room-info-edit-view-announcement')).replaceText('abc'); await element(by.id('room-info-edit-view-password')).replaceText('abc'); await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-t')).tap(); await element(by.id('room-info-edit-view-ro')).tap(); await element(by.id('room-info-edit-view-react-when-ro')).tap(); await element(by.id('room-info-edit-view-reset')).tap(); // after reset await expect(element(by.id('room-info-edit-view-name'))).toHaveText(room); await expect(element(by.id('room-info-edit-view-description'))).toHaveText(''); await expect(element(by.id('room-info-edit-view-topic'))).toHaveText(''); await expect(element(by.id('room-info-edit-view-announcement'))).toHaveText(''); await expect(element(by.id('room-info-edit-view-password'))).toHaveText(''); await expect(element(by.id('room-info-edit-view-t'))).toHaveValue('1'); await expect(element(by.id('room-info-edit-view-ro'))).toHaveValue('0'); await expect(element(by.id('room-info-edit-view-react-when-ro'))).toBeNotVisible(); await element(by.id('room-info-edit-view-list')).swipe('down'); }); it('should change room description', async() => { await element(by.id('room-info-edit-view-description')).replaceText('new description'); await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); await tapBack('Room Info'); await waitFor(element(by.id('room-info-view'))).toBeVisible().withTimeout(2000); await waitFor(element(by.id('room-info-view-description'))).toHaveText('new description').withTimeout(60000); await expect(element(by.id('room-info-view-description'))).toHaveText('new description'); await waitFor(element(by.id('room-info-view-edit-button'))).toBeVisible().withTimeout(10000); await element(by.id('room-info-view-edit-button')).tap(); await waitFor(element(by.id('room-info-edit-view'))).toBeVisible().withTimeout(2000); }); it('should change room topic', async() => { await element(by.id('room-info-edit-view-topic')).replaceText('new topic'); await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); await tapBack('Room Info'); await waitFor(element(by.id('room-info-view'))).toBeVisible().withTimeout(2000); await waitFor(element(by.id('room-info-view-topic'))).toHaveText('new topic').withTimeout(60000); await expect(element(by.id('room-info-view-topic'))).toHaveText('new topic'); await waitFor(element(by.id('room-info-view-edit-button'))).toBeVisible().withTimeout(10000); await element(by.id('room-info-view-edit-button')).tap(); await waitFor(element(by.id('room-info-edit-view'))).toBeVisible().withTimeout(2000); }); it('should change room announcement', async() => { await element(by.id('room-info-edit-view-announcement')).replaceText('new announcement'); await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); await tapBack('Room Info'); await waitFor(element(by.id('room-info-view'))).toBeVisible().withTimeout(2000); await waitFor(element(by.id('room-info-view-announcement'))).toHaveText('new announcement').withTimeout(60000); await expect(element(by.id('room-info-view-announcement'))).toHaveText('new announcement'); await waitFor(element(by.id('room-info-view-edit-button'))).toBeVisible().withTimeout(10000); await element(by.id('room-info-view-edit-button')).tap(); await waitFor(element(by.id('room-info-edit-view'))).toBeVisible().withTimeout(2000); }); it('should change room password', async() => { await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-password')).replaceText('password'); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); }); it('should change room type', async() => { await element(by.id('room-info-edit-view-t')).tap(); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); await element(by.id('room-info-edit-view-t')).tap(); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); }); it('should change room read only and allow reactions', async() => { await element(by.id('room-info-edit-view-ro')).tap(); await waitFor(element(by.id('room-info-edit-view-react-when-ro'))).toBeVisible().withTimeout(2000); await expect(element(by.id('room-info-edit-view-react-when-ro'))).toBeVisible(); await element(by.id('room-info-edit-view-react-when-ro')).tap(); await element(by.id('room-info-edit-view-submit')).tap(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeVisible().withTimeout(60000); await expect(element(by.text('Settings succesfully changed!'))).toBeVisible(); await waitFor(element(by.text('Settings succesfully changed!'))).toBeNotVisible().withTimeout(10000); await expect(element(by.text('Settings succesfully changed!'))).toBeNotVisible(); // TODO: test if it's possible to react }); it('should archive room', async() => { await element(by.id('room-info-edit-view-archive')).tap(); await waitFor(element(by.text('Yes, archive it!'))).toBeVisible().withTimeout(5000); await expect(element(by.text('Yes, archive it!'))).toBeVisible(); await element(by.text('Yes, archive it!')).tap(); await waitFor(element(by.text('UNARCHIVE'))).toBeVisible().withTimeout(60000); await expect(element(by.text('UNARCHIVE'))).toBeVisible(); // TODO: needs permission to unarchive // await element(by.id('room-info-edit-view-archive')).tap(); // await waitFor(element(by.text('Yes, unarchive it!'))).toBeVisible().withTimeout(5000); // await expect(element(by.text('Yes, unarchive it!'))).toBeVisible(); // await element(by.text('Yes, unarchive it!')).tap(); // await waitFor(element(by.text('ARCHIVE'))).toBeVisible().withTimeout(60000); // await expect(element(by.text('ARCHIVE'))).toBeVisible(); }); it('should delete room', async() => { await element(by.id('room-info-edit-view-list')).swipe('up'); await element(by.id('room-info-edit-view-delete')).tap(); await waitFor(element(by.text('Yes, delete it!'))).toBeVisible().withTimeout(5000); await expect(element(by.text('Yes, delete it!'))).toBeVisible(); await element(by.text('Yes, delete it!')).tap(); await waitFor(element(by.id('rooms-list-view'))).toBeVisible().withTimeout(2000); await waitFor(element(by.id(`rooms-list-view-item-${ room }`))).toBeNotVisible().withTimeout(60000); await expect(element(by.id(`rooms-list-view-item-${ room }`))).toBeNotVisible(); }); afterEach(async() => { takeScreenshot(); }); }); }); });