301 lines
13 KiB
JavaScript
301 lines
13 KiB
JavaScript
const {
|
|
device, expect, element, by, waitFor
|
|
} = require('detox');
|
|
const data = require('../../data');
|
|
const { navigateToLogin, login, tapBack, sleep, searchRoom } = require('../../helpers/app');
|
|
|
|
const privateRoomName = data.groups.private.name
|
|
|
|
async function navigateToRoomInfo(type) {
|
|
let room;
|
|
if (type === 'd') {
|
|
room = 'rocket.cat';
|
|
} else {
|
|
room = privateRoomName;
|
|
}
|
|
await searchRoom(room);
|
|
await element(by.id(`rooms-list-view-item-${ room }`)).tap();
|
|
await waitFor(element(by.id('room-view'))).toExist().withTimeout(2000);
|
|
await element(by.id('room-header')).tap();
|
|
await waitFor(element(by.id('room-actions-view'))).toExist().withTimeout(5000);
|
|
await element(by.id('room-actions-info')).tap();
|
|
await waitFor(element(by.id('room-info-view'))).toExist().withTimeout(2000);
|
|
}
|
|
|
|
async function waitForToast() {
|
|
// await waitFor(element(by.id('toast'))).toExist().withTimeout(10000);
|
|
// await expect(element(by.id('toast'))).toExist();
|
|
// await waitFor(element(by.id('toast'))).toBeNotVisible().withTimeout(10000);
|
|
// await expect(element(by.id('toast'))).toBeNotVisible();
|
|
await sleep(300);
|
|
}
|
|
|
|
describe('Room info screen', () => {
|
|
|
|
before(async() => {
|
|
await device.launchApp({ permissions: { notifications: 'YES' }, delete: true });
|
|
await navigateToLogin();
|
|
await login(data.users.regular.username, data.users.regular.password);
|
|
});
|
|
|
|
describe('Direct', async() => {
|
|
before(async() => {
|
|
await navigateToRoomInfo('d');
|
|
});
|
|
|
|
it('should navigate to room info', async() => {
|
|
await expect(element(by.id('room-info-view'))).toExist();
|
|
await expect(element(by.id('room-info-view-name'))).toExist();
|
|
});
|
|
|
|
after(async() => {
|
|
await tapBack()
|
|
await tapBack()
|
|
await tapBack()
|
|
})
|
|
});
|
|
|
|
describe('Channel/Group', async() => {
|
|
before(async() => {
|
|
await navigateToRoomInfo('c');
|
|
});
|
|
|
|
describe('Render', async() => {
|
|
it('should have room info view', async() => {
|
|
await expect(element(by.id('room-info-view'))).toExist();
|
|
});
|
|
|
|
it('should have name', async() => {
|
|
await expect(element(by.id('room-info-view-name'))).toExist();
|
|
});
|
|
|
|
it('should have description', async() => {
|
|
await expect(element(by.label('Description'))).toExist();
|
|
});
|
|
|
|
it('should have topic', async() => {
|
|
await expect(element(by.label('Topic'))).toExist();
|
|
});
|
|
|
|
it('should have announcement', async() => {
|
|
await expect(element(by.label('Announcement'))).toExist();
|
|
});
|
|
|
|
it('should have edit button', async() => {
|
|
await expect(element(by.id('room-info-view-edit-button'))).toExist();
|
|
});
|
|
});
|
|
|
|
describe('Render Edit', async() => {
|
|
before(async() => {
|
|
await waitFor(element(by.id('room-info-view-edit-button'))).toExist().withTimeout(10000);
|
|
await element(by.id('room-info-view-edit-button')).tap();
|
|
await waitFor(element(by.id('room-info-edit-view'))).toExist().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'))).toExist();
|
|
});
|
|
|
|
it('should have topic input', async() => {
|
|
await expect(element(by.id('room-info-edit-view-topic'))).toExist();
|
|
});
|
|
|
|
it('should have announcement input', async() => {
|
|
await expect(element(by.id('room-info-edit-view-announcement'))).toExist();
|
|
});
|
|
|
|
it('should have password input', async() => {
|
|
await expect(element(by.id('room-info-edit-view-password'))).toExist();
|
|
});
|
|
|
|
it('should have type switch', async() => {
|
|
// Ugly hack to scroll on detox
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await expect(element(by.id('room-info-edit-view-t'))).toExist();
|
|
});
|
|
|
|
it('should have ready only switch', async() => {
|
|
await expect(element(by.id('room-info-edit-view-ro'))).toExist();
|
|
});
|
|
|
|
it('should have submit button', async() => {
|
|
await expect(element(by.id('room-info-edit-view-submit'))).toExist();
|
|
});
|
|
|
|
it('should have reset button', async() => {
|
|
await expect(element(by.id('room-info-edit-view-reset'))).toExist();
|
|
});
|
|
|
|
it('should have archive button', async() => {
|
|
await expect(element(by.id('room-info-edit-view-archive'))).toExist();
|
|
});
|
|
|
|
it('should have delete button', async() => {
|
|
await expect(element(by.id('room-info-edit-view-delete'))).toExist();
|
|
});
|
|
|
|
after(async() => {
|
|
// Ugly hack to scroll on detox
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('down');
|
|
});
|
|
});
|
|
|
|
describe('Usage', async() => {
|
|
// it('should enter "invalid name" and get error', async() => {
|
|
// await element(by.type('UIScrollView')).atIndex(1).swipe('down');
|
|
// await element(by.id('room-info-edit-view-name')).replaceText('invalid name');
|
|
// await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
// await element(by.id('room-info-edit-view-submit')).tap();
|
|
// await waitFor(element(by.text('There was an error while saving settings!'))).toExist().withTimeout(60000);
|
|
// await expect(element(by.text('There was an error while saving settings!'))).toExist();
|
|
// await element(by.text('OK')).tap();
|
|
// await waitFor(element(by.text('There was an error while saving settings!'))).toBeNotVisible().withTimeout(10000);
|
|
// await element(by.type('UIScrollView')).atIndex(1).swipe('down');
|
|
// });
|
|
|
|
it('should change room name', async() => {
|
|
await element(by.id('room-info-edit-view-name')).replaceText(`${ privateRoomName }new`);
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
await tapBack();
|
|
await waitFor(element(by.id('room-info-view'))).toExist().withTimeout(2000);
|
|
await expect(element(by.id('room-info-view-name'))).toHaveLabel(`${ privateRoomName }new`);
|
|
// change name to original
|
|
await element(by.id('room-info-view-edit-button')).tap();
|
|
await waitFor(element(by.id('room-info-edit-view'))).toExist().withTimeout(2000);
|
|
await element(by.id('room-info-edit-view-name')).replaceText(`${ privateRoomName }`);
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
await element(by.type('UIScrollView')).atIndex(1).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.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-t')).tap();
|
|
await element(by.id('room-info-edit-view-ro')).longPress(); //https://github.com/facebook/react-native/issues/28032
|
|
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(privateRoomName);
|
|
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.type('UIScrollView')).atIndex(1).swipe('down');
|
|
});
|
|
|
|
it('should change room description', async() => {
|
|
await element(by.id('room-info-edit-view-description')).replaceText('new description');
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
await tapBack();
|
|
await waitFor(element(by.id('room-info-view'))).toExist().withTimeout(2000);
|
|
await expect(element(by.label('new description').withAncestor(by.id('room-info-view-description')))).toExist();
|
|
});
|
|
|
|
it('should change room topic', async() => {
|
|
await waitFor(element(by.id('room-info-view-edit-button'))).toExist().withTimeout(10000);
|
|
await element(by.id('room-info-view-edit-button')).tap();
|
|
await waitFor(element(by.id('room-info-edit-view'))).toExist().withTimeout(2000);
|
|
await element(by.id('room-info-edit-view-topic')).replaceText('new topic');
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
await tapBack();
|
|
await waitFor(element(by.id('room-info-view'))).toExist().withTimeout(2000);
|
|
await expect(element(by.label('new topic').withAncestor(by.id('room-info-view-topic')))).toExist();
|
|
});
|
|
|
|
it('should change room announcement', async() => {
|
|
await waitFor(element(by.id('room-info-view-edit-button'))).toExist().withTimeout(10000);
|
|
await element(by.id('room-info-view-edit-button')).tap();
|
|
await waitFor(element(by.id('room-info-edit-view'))).toExist().withTimeout(2000);
|
|
await element(by.id('room-info-edit-view-announcement')).replaceText('new announcement');
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
await tapBack();
|
|
await waitFor(element(by.id('room-info-view'))).toExist().withTimeout(2000);
|
|
await expect(element(by.label('new announcement').withAncestor(by.id('room-info-view-announcement')))).toExist();
|
|
});
|
|
|
|
it('should change room password', async() => {
|
|
await waitFor(element(by.id('room-info-view-edit-button'))).toExist().withTimeout(10000);
|
|
await element(by.id('room-info-view-edit-button')).tap();
|
|
await waitFor(element(by.id('room-info-edit-view'))).toExist().withTimeout(2000);
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-password')).replaceText('password');
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
});
|
|
|
|
it('should change room type', async() => {
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-t')).tap();
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
await element(by.id('room-info-edit-view-t')).tap();
|
|
await element(by.id('room-info-edit-view-submit')).tap();
|
|
await waitForToast();
|
|
});
|
|
|
|
// it('should change room read only and allow reactions', async() => {
|
|
// await sleep(1000);
|
|
// await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
// await element(by.id('room-info-edit-view-ro')).tap();
|
|
// await waitFor(element(by.id('room-info-edit-view-react-when-ro'))).toExist().withTimeout(2000);
|
|
// await expect(element(by.id('room-info-edit-view-react-when-ro'))).toExist();
|
|
// await element(by.id('room-info-edit-view-react-when-ro')).tap();
|
|
// await element(by.id('room-info-edit-view-submit')).tap();
|
|
// await waitForToast();
|
|
// // TODO: test if it's possible to react
|
|
// });
|
|
|
|
it('should archive room', async() => {
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-archive')).tap();
|
|
await waitFor(element(by.text('Yes, archive it!'))).toExist().withTimeout(5000);
|
|
await element(by.text('Yes, archive it!')).tap();
|
|
await waitFor(element(by.id('room-info-edit-view-unarchive'))).toExist().withTimeout(60000);
|
|
await expect(element(by.id('room-info-edit-view-archive'))).toBeNotVisible();
|
|
// TODO: needs permission to unarchive
|
|
// await element(by.id('room-info-edit-view-archive')).tap();
|
|
// await waitFor(element(by.text('Yes, unarchive it!'))).toExist().withTimeout(5000);
|
|
// await expect(element(by.text('Yes, unarchive it!'))).toExist();
|
|
// await element(by.text('Yes, unarchive it!')).tap();
|
|
// await waitFor(element(by.text('ARCHIVE'))).toExist().withTimeout(60000);
|
|
// await expect(element(by.text('ARCHIVE'))).toExist();
|
|
});
|
|
|
|
it('should delete room', async() => {
|
|
await element(by.type('UIScrollView')).atIndex(1).swipe('up');
|
|
await element(by.id('room-info-edit-view-delete')).tap();
|
|
await waitFor(element(by.text('Yes, delete it!'))).toExist().withTimeout(5000);
|
|
await element(by.text('Yes, delete it!')).tap();
|
|
await waitFor(element(by.id('rooms-list-view'))).toExist().withTimeout(10000);
|
|
await waitFor(element(by.id(`rooms-list-view-item-${ privateRoomName }`))).toBeNotVisible().withTimeout(60000);
|
|
});
|
|
});
|
|
});
|
|
});
|