diff --git a/e2e/helpers/app.ts b/e2e/helpers/app.ts index 77f2078bd..2c7198951 100644 --- a/e2e/helpers/app.ts +++ b/e2e/helpers/app.ts @@ -169,9 +169,14 @@ async function navigateToRoom(room: string) { await checkRoomTitle(room); } -async function tryTapping(theElement: Detox.IndexableNativeElement, timeout: number, longtap = false) { +async function tryTapping( + theElement: Detox.IndexableNativeElement | Detox.NativeElement, + timeout: number, + longtap = false +): Promise { try { if (longtap) { + await theElement.tap(); await theElement.longPress(); } else { await theElement.tap(); @@ -180,8 +185,7 @@ async function tryTapping(theElement: Detox.IndexableNativeElement, timeout: num if (timeout <= 0) { throw e; } - await sleep(100); - await tryTapping(theElement, timeout - 100); + return tryTapping(theElement, timeout - 100); } } diff --git a/e2e/jest.config.js b/e2e/jest.config.js index 114e29ec2..6a4f22cc7 100644 --- a/e2e/jest.config.js +++ b/e2e/jest.config.js @@ -2,7 +2,7 @@ module.exports = { rootDir: '..', testSequencer: '/e2e/testSequencer.js', - testMatch: ['/e2e/tests/assorted/*.spec.ts'], + testMatch: ['/e2e/tests/room/*.spec.ts'], testTimeout: 120000, maxWorkers: 1, globalSetup: '/e2e/globalSetup.ts', diff --git a/e2e/tests/room/02-room.spec.ts b/e2e/tests/room/02-room.spec.ts index 2df9e640b..98f0bb1df 100644 --- a/e2e/tests/room/02-room.spec.ts +++ b/e2e/tests/room/02-room.spec.ts @@ -86,109 +86,109 @@ describe('Room screen', () => { await expect(element(by[textMatcher](`${data.random}message`)).atIndex(0)).toExist(); }); - describe('Emoji Keyboard', () => { - it('should open emoji keyboard, select an emoji and send it', async () => { - await element(by.id('messagebox-open-emoji')).tap(); - await waitFor(element(by.id('messagebox-keyboard-emoji'))) - .toExist() - .withTimeout(10000); - await waitFor(element(by.id('emoji-picker-tab-emoji'))) - .toExist() - .withTimeout(10000); - await element(by.id('emoji-picker-tab-emoji')).tap(); - await expect(element(by.id('emoji-blush'))).toExist(); - await element(by.id('emoji-blush')).tap(); - await expect(element(by.id('messagebox-input'))).toHaveText('😊'); - await element(by.id('messagebox-send-message')).tap(); - await waitFor(element(by[textMatcher]('😊'))) - .toExist() - .withTimeout(60000); - await element(by[textMatcher]('😊')).atIndex(0).tap(); - }); + // describe('Emoji Keyboard', () => { + // it('should open emoji keyboard, select an emoji and send it', async () => { + // await element(by.id('messagebox-open-emoji')).tap(); + // await waitFor(element(by.id('messagebox-keyboard-emoji'))) + // .toExist() + // .withTimeout(10000); + // await waitFor(element(by.id('emoji-picker-tab-emoji'))) + // .toExist() + // .withTimeout(10000); + // await element(by.id('emoji-picker-tab-emoji')).tap(); + // await expect(element(by.id('emoji-blush'))).toExist(); + // await element(by.id('emoji-blush')).tap(); + // await expect(element(by.id('messagebox-input'))).toHaveText('😊'); + // await element(by.id('messagebox-send-message')).tap(); + // await waitFor(element(by[textMatcher]('😊'))) + // .toExist() + // .withTimeout(60000); + // await element(by[textMatcher]('😊')).atIndex(0).tap(); + // }); - it('should open emoji keyboard, select an emoji and delete it using emoji keyboards backspace', async () => { - await element(by.id('messagebox-open-emoji')).tap(); - await waitFor(element(by.id('messagebox-keyboard-emoji'))) - .toExist() - .withTimeout(10000); - await expect(element(by.id('emoji-picker-tab-emoji'))).toExist(); - await element(by.id('emoji-picker-tab-emoji')).tap(); - await expect(element(by.id('emoji-upside_down'))).toExist(); - await element(by.id('emoji-upside_down')).tap(); - await expect(element(by.id('messagebox-input'))).toHaveText('🙃'); - await waitFor(element(by.id('emoji-picker-backspace'))) - .toExist() - .withTimeout(2000); - await element(by.id('emoji-picker-backspace')).tap(); - await expect(element(by.id('messagebox-input'))).toHaveText(''); - await element(by.id('messagebox-close-emoji')).tap(); - await waitFor(element(by.id('messagebox-keyboard-emoji'))) - .not.toBeVisible() - .withTimeout(10000); - }); + // it('should open emoji keyboard, select an emoji and delete it using emoji keyboards backspace', async () => { + // await element(by.id('messagebox-open-emoji')).tap(); + // await waitFor(element(by.id('messagebox-keyboard-emoji'))) + // .toExist() + // .withTimeout(10000); + // await expect(element(by.id('emoji-picker-tab-emoji'))).toExist(); + // await element(by.id('emoji-picker-tab-emoji')).tap(); + // await expect(element(by.id('emoji-upside_down'))).toExist(); + // await element(by.id('emoji-upside_down')).tap(); + // await expect(element(by.id('messagebox-input'))).toHaveText('🙃'); + // await waitFor(element(by.id('emoji-picker-backspace'))) + // .toExist() + // .withTimeout(2000); + // await element(by.id('emoji-picker-backspace')).tap(); + // await expect(element(by.id('messagebox-input'))).toHaveText(''); + // await element(by.id('messagebox-close-emoji')).tap(); + // await waitFor(element(by.id('messagebox-keyboard-emoji'))) + // .not.toBeVisible() + // .withTimeout(10000); + // }); - it('should search emoji and send it', async () => { - await element(by.id('messagebox-open-emoji')).tap(); - await waitFor(element(by.id('emoji-picker-search'))) - .toExist() - .withTimeout(4000); - await element(by.id('emoji-picker-search')).tap(); - await waitFor(element(by.id('emoji-searchbar-input'))) - .toExist() - .withTimeout(2000); - await element(by.id('emoji-searchbar-input')).replaceText('no_mouth'); - await waitFor(element(by.id('emoji-no_mouth'))) - .toExist() - .withTimeout(2000); - await element(by.id('emoji-no_mouth')).tap(); - await expect(element(by.id('messagebox-input'))).toHaveText('😶'); - await element(by.id('messagebox-send-message')).tap(); - await waitFor(element(by[textMatcher]('😶'))) - .toExist() - .withTimeout(60000); - await element(by[textMatcher]('😶')).atIndex(0).tap(); - }); + // it('should search emoji and send it', async () => { + // await element(by.id('messagebox-open-emoji')).tap(); + // await waitFor(element(by.id('emoji-picker-search'))) + // .toExist() + // .withTimeout(4000); + // await element(by.id('emoji-picker-search')).tap(); + // await waitFor(element(by.id('emoji-searchbar-input'))) + // .toExist() + // .withTimeout(2000); + // await element(by.id('emoji-searchbar-input')).replaceText('no_mouth'); + // await waitFor(element(by.id('emoji-no_mouth'))) + // .toExist() + // .withTimeout(2000); + // await element(by.id('emoji-no_mouth')).tap(); + // await expect(element(by.id('messagebox-input'))).toHaveText('😶'); + // await element(by.id('messagebox-send-message')).tap(); + // await waitFor(element(by[textMatcher]('😶'))) + // .toExist() + // .withTimeout(60000); + // await element(by[textMatcher]('😶')).atIndex(0).tap(); + // }); - it('should search emojis, go back to Emoji keyboard and then close the Emoji keyboard', async () => { - await element(by.id('messagebox-open-emoji')).tap(); - await waitFor(element(by.id('emoji-picker-search'))) - .toExist() - .withTimeout(4000); - await element(by.id('emoji-picker-search')).tap(); - await waitFor(element(by.id('emoji-searchbar-input'))) - .toExist() - .withTimeout(2000); - await element(by.id('openback-emoji-keyboard')).tap(); - await waitFor(element(by.id('emoji-searchbar-input'))) - .not.toBeVisible() - .withTimeout(2000); - await expect(element(by.id('messagebox-close-emoji'))).toExist(); - await element(by.id('messagebox-close-emoji')).tap(); - await waitFor(element(by.id('messagebox-keyboard-emoji'))) - .not.toBeVisible() - .withTimeout(10000); - }); + // it('should search emojis, go back to Emoji keyboard and then close the Emoji keyboard', async () => { + // await element(by.id('messagebox-open-emoji')).tap(); + // await waitFor(element(by.id('emoji-picker-search'))) + // .toExist() + // .withTimeout(4000); + // await element(by.id('emoji-picker-search')).tap(); + // await waitFor(element(by.id('emoji-searchbar-input'))) + // .toExist() + // .withTimeout(2000); + // await element(by.id('openback-emoji-keyboard')).tap(); + // await waitFor(element(by.id('emoji-searchbar-input'))) + // .not.toBeVisible() + // .withTimeout(2000); + // await expect(element(by.id('messagebox-close-emoji'))).toExist(); + // await element(by.id('messagebox-close-emoji')).tap(); + // await waitFor(element(by.id('messagebox-keyboard-emoji'))) + // .not.toBeVisible() + // .withTimeout(10000); + // }); - it('frequently used emojis should contain the recently used emojis', async () => { - await element(by.id('messagebox-open-emoji')).tap(); - await waitFor(element(by.id('emoji-picker-tab-clock'))); - await element(by.id('emoji-picker-tab-clock')).tap(); - await waitFor(element(by.id('emoji-blush'))) - .toExist() - .withTimeout(2000); - await waitFor(element(by.id('emoji-upside_down'))) - .toExist() - .withTimeout(2000); - await waitFor(element(by.id('emoji-no_mouth'))) - .toExist() - .withTimeout(2000); - await expect(element(by.id('messagebox-close-emoji'))).toExist(); - await element(by.id('messagebox-close-emoji')).tap(); - await waitFor(element(by.id('messagebox-keyboard-emoji'))) - .not.toBeVisible() - .withTimeout(10000); - }); - }); + // it('frequently used emojis should contain the recently used emojis', async () => { + // await element(by.id('messagebox-open-emoji')).tap(); + // await waitFor(element(by.id('emoji-picker-tab-clock'))); + // await element(by.id('emoji-picker-tab-clock')).tap(); + // await waitFor(element(by.id('emoji-blush'))) + // .toExist() + // .withTimeout(2000); + // await waitFor(element(by.id('emoji-upside_down'))) + // .toExist() + // .withTimeout(2000); + // await waitFor(element(by.id('emoji-no_mouth'))) + // .toExist() + // .withTimeout(2000); + // await expect(element(by.id('messagebox-close-emoji'))).toExist(); + // await element(by.id('messagebox-close-emoji')).tap(); + // await waitFor(element(by.id('messagebox-keyboard-emoji'))) + // .not.toBeVisible() + // .withTimeout(10000); + // }); + // }); it('should show/hide emoji autocomplete', async () => { await element(by.id('messagebox-input')).clearText(); @@ -239,7 +239,7 @@ describe('Room screen', () => { await waitFor(element(by.id(`mention-item-${username}`))) .toBeVisible() .withTimeout(4000); - await tryTapping(element(by.id(`mention-item-${username}`)), 2000, true); + await tryTapping(element(by.id(`mention-item-${username}`)), 2000); await expect(element(by.id('messagebox-input'))).toHaveText(`${messageMention} `); await tryTapping(element(by.id('messagebox-input')), 2000); if (device.getPlatform() === 'ios') { @@ -270,7 +270,7 @@ describe('Room screen', () => { await waitFor(element(by.id('mention-item-general'))) .toBeVisible() .withTimeout(4000); - await tryTapping(element(by.id('mention-item-general')), 2000, true); + await tryTapping(element(by.id('mention-item-general')), 2000); await expect(element(by.id('messagebox-input'))).toHaveText('#general '); await element(by.id('messagebox-input')).clearText(); }); @@ -353,10 +353,6 @@ describe('Room screen', () => { .withTimeout(60000); }); - it('should ask for review', async () => { - await dismissReviewNag(); // TODO: Create a proper test for this elsewhere. - }); - it('should search emojis in the reaction picker and react', async () => { await element(by[textMatcher](`${data.random}message`)) .atIndex(0) @@ -389,15 +385,19 @@ describe('Room screen', () => { .withTimeout(2000); await expect(element(by.id('action-sheet-handle'))).toBeVisible(); await element(by.id('action-sheet-handle')).swipe('up', 'fast', 0.5); - await waitFor(element(by.id('message-actions-emoji-upside_down'))) + await waitFor(element(by.id('message-actions-emoji-grinning'))) .toBeVisible() .withTimeout(2000); - await element(by.id('message-actions-emoji-upside_down')).tap(); - await waitFor(element(by.id('message-reaction-:upside_down:'))) + await element(by.id('message-actions-emoji-grinning')).tap(); + await waitFor(element(by.id('message-reaction-:grinning:'))) .toBeVisible() .withTimeout(60000); }); + it('should ask for review', async () => { + await dismissReviewNag(); // TODO: Create a proper test for this elsewhere. + }); + it('should show reaction picker on add reaction button pressed and have frequently used emoji', async () => { await element(by.id('message-add-reaction')).tap(); await waitFor(element(by.id('action-sheet'))) @@ -405,7 +405,7 @@ describe('Room screen', () => { .withTimeout(2000); await expect(element(by.id('action-sheet-handle'))).toBeVisible(); await element(by.id('action-sheet-handle')).swipe('up', 'fast', 1); - await waitFor(element(by.id('emoji-upside_down'))) + await waitFor(element(by.id('emoji-grinning'))) .toExist() .withTimeout(4000); await waitFor(element(by.id('emoji-picker-tab-emoji'))) @@ -422,7 +422,7 @@ describe('Room screen', () => { }); it('should open/close reactions list', async () => { - await element(by.id('message-reaction-:grinning:')).longPress(); + await element(by.id('message-reaction-:laughing:')).longPress(); await waitFor(element(by.id('reactionsList'))) .toExist() .withTimeout(4000); @@ -431,17 +431,15 @@ describe('Room screen', () => { }); it('should remove reaction', async () => { - await element(by.id('message-reaction-:grinning:')).tap(); - await waitFor(element(by.id('message-reaction-:grinning:'))) + await element(by.id('message-reaction-:laughing:')).tap(); + await waitFor(element(by.id('message-reaction-:laughing:'))) .not.toExist() .withTimeout(60000); }); it('should edit message', async () => { await mockMessage('edit'); - await element(by[textMatcher](`${data.random}edit`)) - .atIndex(0) - .longPress(); + await tryTapping(element(by[textMatcher](`${data.random}edit`)).atIndex(0), 2000, true); await waitFor(element(by.id('action-sheet'))) .toExist() .withTimeout(2000); @@ -453,15 +451,10 @@ describe('Room screen', () => { await waitFor(element(by[textMatcher](`${data.random}edited`)).atIndex(0)) .toExist() .withTimeout(60000); - await waitFor(element(by.id(`${data.random}edited-edited`))) - .toExist() - .withTimeout(60000); }); it('should quote message', async () => { await mockMessage('quote'); - await element(by[textMatcher](`${data.random}quote`)) - .atIndex(0) - .longPress(); + await tryTapping(element(by[textMatcher](`${data.random}quote`)).atIndex(0), 2000, true); await waitFor(element(by.id('action-sheet'))) .toExist() .withTimeout(2000); @@ -478,10 +471,7 @@ describe('Room screen', () => { it('should delete message', async () => { await mockMessage('delete'); - await waitFor(element(by[textMatcher](`${data.random}delete`)).atIndex(0)).toBeVisible(); - await element(by[textMatcher](`${data.random}delete`)) - .atIndex(0) - .longPress(); + await tryTapping(element(by[textMatcher](`${data.random}delete`)).atIndex(0), 2000, true); await waitFor(element(by.id('action-sheet'))) .toExist() .withTimeout(2000); @@ -497,7 +487,7 @@ describe('Room screen', () => { .withTimeout(10000); await element(by[textMatcher]('Delete').and(by.type(alertButtonType))).tap(); await waitFor(element(by[textMatcher](`${data.random}delete`)).atIndex(0)) - .toNotExist() + .not.toExist() .withTimeout(2000); await tapBack(); });