2023-02-04 16:19:37 +00:00
|
|
|
import { test, expect } from '@playwright/test'
|
|
|
|
|
2023-02-16 13:31:52 +00:00
|
|
|
const navigationVias = ['time link', 'toot content'] as const
|
|
|
|
|
|
|
|
navigationVias.forEach((via) =>
|
|
|
|
test(`Navigation to and view of an individual toot via ${via}`, async ({ page }) => {
|
|
|
|
await page.goto('http://127.0.0.1:8788/explore')
|
|
|
|
if (via === 'time link') {
|
|
|
|
await page.locator('article').filter({ hasText: 'Ben, just Ben' }).locator('i.fa-globe + span').click()
|
|
|
|
} else {
|
|
|
|
await page.getByText('A very simple update: all good!').click()
|
|
|
|
}
|
|
|
|
await expect(page.getByRole('button', { name: 'Back' })).toBeVisible()
|
|
|
|
await expect(page.getByRole('link', { name: 'Avatar of Ben, just Ben' })).toBeVisible()
|
|
|
|
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Ben, just Ben' })).toBeVisible()
|
|
|
|
await expect(page.locator('span', { hasText: 'A very simple update: all good!' })).toBeVisible()
|
|
|
|
})
|
|
|
|
)
|
2023-02-04 16:19:37 +00:00
|
|
|
|
2023-02-14 21:16:51 +00:00
|
|
|
test('Navigation to and view of an individual toot with images', async ({ page }) => {
|
|
|
|
await page.goto('http://127.0.0.1:8788/explore')
|
|
|
|
await page
|
|
|
|
.locator('article')
|
|
|
|
.filter({ hasText: "I'm Rafael and I am a web designer!" })
|
|
|
|
.locator('i.fa-globe + span')
|
|
|
|
.click()
|
|
|
|
await expect(page.getByRole('button', { name: 'Back' })).toBeVisible()
|
|
|
|
await expect(page.getByRole('link', { name: 'Avatar of Raffa123$' })).toBeVisible()
|
2023-02-16 13:31:52 +00:00
|
|
|
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Raffa123$' })).toBeVisible()
|
2023-02-14 21:16:51 +00:00
|
|
|
await expect(page.locator('p', { hasText: "I'm Rafael and I am a web designer!" })).toBeVisible()
|
|
|
|
expect(await page.getByTestId('media-gallery').getByRole('img').count()).toBe(4)
|
|
|
|
await expect(page.getByTestId('images-modal')).not.toBeVisible()
|
|
|
|
await page.getByTestId('media-gallery').getByRole('img').nth(2).click()
|
|
|
|
await expect(page.getByTestId('images-modal')).toBeVisible()
|
|
|
|
for (const n of [2, 1, 0, 3, 2, 1, 0, 3]) {
|
|
|
|
await expect(page.getByTestId('images-modal').getByRole('img')).toHaveAttribute(
|
|
|
|
'src',
|
|
|
|
`https://loremflickr.com/640/480/abstract?lock=${100 + n}`
|
|
|
|
)
|
|
|
|
await page.getByTestId('left-btn').click()
|
|
|
|
}
|
|
|
|
await page.getByTestId('close-btn').click()
|
|
|
|
await expect(page.getByTestId('images-modal')).not.toBeVisible()
|
2023-02-04 16:19:37 +00:00
|
|
|
})
|
2023-02-07 11:12:59 +00:00
|
|
|
|
2023-02-07 14:37:59 +00:00
|
|
|
test("Navigation to and view of a toot's replies", async ({ page }) => {
|
2023-02-07 11:12:59 +00:00
|
|
|
await page.goto('http://127.0.0.1:8788/explore')
|
|
|
|
|
|
|
|
await page
|
|
|
|
.locator('article')
|
2023-02-14 21:16:51 +00:00
|
|
|
.filter({ hasText: 'George' })
|
2023-02-07 11:12:59 +00:00
|
|
|
.filter({
|
2023-02-14 21:16:51 +00:00
|
|
|
hasText: 'We did it!',
|
2023-02-07 11:12:59 +00:00
|
|
|
})
|
|
|
|
.locator('i.fa-globe + span')
|
|
|
|
.click()
|
|
|
|
|
|
|
|
await page
|
|
|
|
.locator('article')
|
2023-02-14 21:16:51 +00:00
|
|
|
.filter({ hasText: 'Zak Smith' })
|
2023-02-07 11:12:59 +00:00
|
|
|
.filter({
|
|
|
|
hasText: 'Yes we did!',
|
|
|
|
})
|
|
|
|
.locator('i.fa-globe + span')
|
|
|
|
.click()
|
|
|
|
|
2023-02-14 21:16:51 +00:00
|
|
|
await expect(page.getByRole('link', { name: 'Avatar of Zak Smith' })).toBeVisible()
|
2023-02-16 13:31:52 +00:00
|
|
|
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Zak Smith' })).toBeVisible()
|
2023-02-07 11:12:59 +00:00
|
|
|
await expect(page.getByText('Yes we did!')).toBeVisible()
|
2023-02-07 14:37:59 +00:00
|
|
|
|
|
|
|
await page.getByRole('button', { name: 'Back' }).click()
|
|
|
|
|
|
|
|
await page
|
|
|
|
.locator('article')
|
2023-02-14 21:16:51 +00:00
|
|
|
.filter({ hasText: 'Penny' })
|
2023-02-07 14:37:59 +00:00
|
|
|
.filter({
|
|
|
|
hasText: 'Yes you guys did it!',
|
|
|
|
})
|
|
|
|
.locator('i.fa-globe + span')
|
|
|
|
.click()
|
|
|
|
|
2023-02-14 21:16:51 +00:00
|
|
|
await expect(page.getByRole('link', { name: 'Avatar of Penny' })).toBeVisible()
|
2023-02-16 13:31:52 +00:00
|
|
|
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Penny' })).toBeVisible()
|
2023-02-07 14:37:59 +00:00
|
|
|
await expect(page.getByText('Yes you guys did it!')).toBeVisible()
|
2023-02-07 11:12:59 +00:00
|
|
|
})
|
2023-02-16 16:58:03 +00:00
|
|
|
|
|
|
|
test("Correctly hides and displays the toot's content based on the spoiler text", async ({ page }) => {
|
|
|
|
await page.goto('http://127.0.0.1:8788/explore')
|
|
|
|
|
|
|
|
await page.getByText('who am I?').click()
|
|
|
|
|
|
|
|
await expect(page.getByRole('button', { name: 'Back' })).toBeVisible()
|
|
|
|
|
|
|
|
const articleLocator = page.getByRole('article').filter({ hasText: 'who am I?' })
|
|
|
|
await expect(articleLocator.getByRole('paragraph').getByText('Hi! My name is Rafael! 👋')).not.toBeVisible()
|
|
|
|
await articleLocator.getByRole('button', { name: 'show more' }).click()
|
|
|
|
await expect(articleLocator.getByRole('paragraph').getByText('Hi! My name is Rafael! 👋')).toBeVisible()
|
|
|
|
await articleLocator.getByRole('button', { name: 'show less' }).click()
|
|
|
|
await expect(articleLocator.getByRole('paragraph').getByText('Hi! My name is Rafael! 👋')).not.toBeVisible()
|
|
|
|
})
|