wildebeest/ui-e2e-tests/invidivual-toot.spec.ts

101 wiersze
4.1 KiB
TypeScript
Czysty Zwykły widok Historia

import { test, expect } from '@playwright/test'
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()
})
)
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()
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Raffa123$' })).toBeVisible()
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()
})
test("Navigation to and view of a toot's replies", async ({ page }) => {
await page.goto('http://127.0.0.1:8788/explore')
await page
.locator('article')
.filter({ hasText: 'George' })
.filter({
hasText: 'We did it!',
})
.locator('i.fa-globe + span')
.click()
await page
.locator('article')
.filter({ hasText: 'Zak Smith' })
.filter({
hasText: 'Yes we did!',
})
.locator('i.fa-globe + span')
.click()
await expect(page.getByRole('link', { name: 'Avatar of Zak Smith' })).toBeVisible()
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Zak Smith' })).toBeVisible()
await expect(page.getByText('Yes we did!')).toBeVisible()
await page.getByRole('button', { name: 'Back' }).click()
await page
.locator('article')
.filter({ hasText: 'Penny' })
.filter({
hasText: 'Yes you guys did it!',
})
.locator('i.fa-globe + span')
.click()
await expect(page.getByRole('link', { name: 'Avatar of Penny' })).toBeVisible()
await expect(page.getByTestId('account-display-name').filter({ hasText: 'Penny' })).toBeVisible()
await expect(page.getByText('Yes you guys did it!')).toBeVisible()
})
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()
})