about summary refs log tree commit diff
path: root/__e2e__/tests/composer.test.ts
blob: 06781410f6fd2f6dab38fad5e30173ac6fea097c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/* eslint-env detox/detox */

import {beforeAll, describe, it} from '@jest/globals'
import {expect} from 'detox'

import {createServer, loginAsAlice, openApp, sleep} from '../util'

describe('Composer', () => {
  beforeAll(async () => {
    await createServer('?users')
    await openApp({
      permissions: {notifications: 'YES', medialibrary: 'YES', photos: 'YES'},
    })
  })

  it('Login', async () => {
    await loginAsAlice()
    await element(by.id('homeScreenFeedTabs-Following')).tap()
  })

  it('Post text only', async () => {
    await element(by.id('composeFAB')).tap()
    await device.takeScreenshot('1- opened composer')
    await element(by.id('composerTextInput')).typeText('Post text only')
    await device.takeScreenshot('2- entered text')
    await element(by.id('composerPublishBtn')).tap()
    await device.takeScreenshot('3- opened general section')
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('Post with an image', async () => {
    await element(by.id('composeFAB')).tap()
    await element(by.id('composerTextInput')).typeText('Post with an image')
    await element(by.id('openGalleryBtn')).tap()
    await sleep(1e3)
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('Post with a link card', async () => {
    await element(by.id('composeFAB')).tap()
    await element(by.id('composerTextInput')).typeText(
      'Post with a https://example.com link card',
    )
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('Reply text only', async () => {
    await element(by.id('e2eRefreshHome')).tap()

    const post = by.id('feedItem-by-alice.test')
    await element(by.id('replyBtn').withAncestor(post)).atIndex(0).tap()
    await element(by.id('composerTextInput')).typeText('Reply text only')
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('Reply with an image', async () => {
    const post = by.id('feedItem-by-alice.test')
    await element(by.id('replyBtn').withAncestor(post)).atIndex(0).tap()
    await element(by.id('composerTextInput')).typeText('Reply with an image')
    await element(by.id('openGalleryBtn')).tap()
    await sleep(1e3)
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('Reply with a link card', async () => {
    const post = by.id('feedItem-by-alice.test')
    await element(by.id('replyBtn').withAncestor(post)).atIndex(0).tap()
    await element(by.id('composerTextInput')).typeText(
      'Reply with a https://example.com link card',
    )
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('QP text only', async () => {
    const post = by.id('feedItem-by-alice.test')
    await element(by.id('repostBtn').withAncestor(post)).atIndex(0).tap()
    await element(by.id('quoteBtn').withAncestor(by.id('repostModal'))).tap()
    await element(by.id('composerTextInput')).typeText('QP text only')
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('QP with an image', async () => {
    const post = by.id('feedItem-by-alice.test')
    await element(by.id('repostBtn').withAncestor(post)).atIndex(0).tap()
    await element(by.id('quoteBtn').withAncestor(by.id('repostModal'))).tap()
    await element(by.id('composerTextInput')).typeText('QP with an image')
    await element(by.id('openGalleryBtn')).tap()
    await sleep(1e3)
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })

  it('QP with a link card', async () => {
    const post = by.id('feedItem-by-alice.test')
    await element(by.id('repostBtn').withAncestor(post)).atIndex(0).tap()
    await element(by.id('quoteBtn').withAncestor(by.id('repostModal'))).tap()
    await element(by.id('composerTextInput')).typeText(
      'QP with a https://example.com link card',
    )
    await element(by.id('composerPublishBtn')).tap()
    await expect(element(by.id('composeFAB'))).toBeVisible()
  })
})