90 lines
2.7 KiB
JavaScript
90 lines
2.7 KiB
JavaScript
import { randomUUID } from 'node:crypto'
|
|
import { expect, test } from 'playwright/test'
|
|
|
|
const createTestUser = () => {
|
|
const id = randomUUID().slice(0, 8)
|
|
return {
|
|
username: `e2e_${id}`,
|
|
fullname: `E2E ${id}`,
|
|
email: `e2e_${id}@example.com`,
|
|
password: 'e2e-password',
|
|
}
|
|
}
|
|
|
|
const register = async (page, user) => {
|
|
await page.goto('/registration')
|
|
|
|
const registrationForm = page.locator('#main-scroller form.registration-form')
|
|
await registrationForm.locator('#sign-up-username').fill(user.username)
|
|
await registrationForm.locator('#sign-up-fullname').fill(user.fullname)
|
|
await registrationForm.locator('#email').fill(user.email)
|
|
await registrationForm.locator('#sign-up-password').fill(user.password)
|
|
await registrationForm
|
|
.locator('#sign-up-password-confirmation')
|
|
.fill(user.password)
|
|
await Promise.all([
|
|
page.waitForURL(/\/main\/friends/),
|
|
registrationForm.getByRole('button', { name: 'Register' }).click(),
|
|
])
|
|
}
|
|
|
|
const logout = async (page) => {
|
|
await page.getByTitle('Log out').click()
|
|
const confirmLogout = page.getByRole('button', {
|
|
name: 'Logout',
|
|
exact: true,
|
|
})
|
|
if (await confirmLogout.isVisible()) {
|
|
await Promise.all([
|
|
page.waitForURL(/\/main\/(public|all)/),
|
|
confirmLogout.click(),
|
|
])
|
|
} else {
|
|
await page.waitForURL(/\/main\/(public|all)/)
|
|
}
|
|
|
|
await expect(page.locator('#sidebar form.login-form')).toBeVisible()
|
|
}
|
|
|
|
const login = async (page, user) => {
|
|
await page.goto('/login')
|
|
|
|
const loginForm = page.locator('#main-scroller form.login-form')
|
|
await loginForm.locator('#username').fill(user.username)
|
|
await loginForm.locator('#password').fill(user.password)
|
|
await loginForm.getByRole('button', { name: 'Log in' }).click()
|
|
|
|
await page.waitForURL(/\/main\/friends/)
|
|
}
|
|
|
|
test('user can register, log out, and log back in', async ({ page }) => {
|
|
const user = createTestUser()
|
|
await register(page, user)
|
|
await expect(page.getByTitle('Log out')).toBeVisible()
|
|
|
|
await logout(page)
|
|
|
|
await login(page, user)
|
|
await expect(page.getByTitle('Log out')).toBeVisible()
|
|
})
|
|
|
|
test('user can post a status', async ({ page }) => {
|
|
const user = createTestUser()
|
|
await register(page, user)
|
|
|
|
const statusText = `Hello from ${user.username} (${randomUUID().slice(0, 8)})`
|
|
const composer = page.locator('#sidebar .user-panel .post-status-form')
|
|
await composer.locator('textarea.form-post-body').fill(statusText)
|
|
await Promise.all([
|
|
page.waitForResponse(
|
|
(resp) =>
|
|
resp.request().method() === 'POST' &&
|
|
resp.url().includes('/api/v1/statuses') &&
|
|
resp.ok(),
|
|
),
|
|
composer.getByRole('button', { name: 'Post', exact: true }).click(),
|
|
])
|
|
|
|
await page.goto(`/users/${user.username}`)
|
|
await expect(page.getByText(statusText)).toBeVisible()
|
|
})
|