Make customer-facing UI usable on smartphones. #6
1 changed files with 43 additions and 23 deletions
|
|
@ -35,6 +35,34 @@ test.describe('Deferred payment and admin lookup', () => {
|
|||
await page.getByRole('button', { name: 'Ja, jag har betalat' }).click()
|
||||
}
|
||||
|
||||
async function openAdminTodoBoard(page: import('@playwright/test').Page) {
|
||||
await page.goto('/admin')
|
||||
await expect(page.locator('.admin__loading')).toBeHidden({ timeout: 30_000 })
|
||||
await page.getByRole('button', { name: /Att göra/ }).click()
|
||||
}
|
||||
|
||||
async function searchAdminOrders(
|
||||
page: import('@playwright/test').Page,
|
||||
query: string,
|
||||
) {
|
||||
const search = page.locator('#admin-order-search')
|
||||
await search.clear()
|
||||
await search.fill(query)
|
||||
await expect(search).toHaveValue(query)
|
||||
}
|
||||
|
||||
async function expectAdminOrderRow(
|
||||
page: import('@playwright/test').Page,
|
||||
options: { shortOrderId: string; plate: string; todo?: boolean },
|
||||
) {
|
||||
const row = page.locator('.admin__row', { hasText: options.shortOrderId })
|
||||
await expect(row).toBeVisible({ timeout: 15_000 })
|
||||
await expect(row.locator('.admin__plate')).toHaveText(options.plate)
|
||||
if (options.todo) {
|
||||
await expect(row).toHaveClass(/admin__row--todo/)
|
||||
}
|
||||
}
|
||||
|
||||
test('user creates order, leaves payment, and pays later from orders', async ({
|
||||
page,
|
||||
}) => {
|
||||
|
|
@ -74,43 +102,36 @@ test.describe('Deferred payment and admin lookup', () => {
|
|||
page,
|
||||
}) => {
|
||||
await loginAsAdmin(page)
|
||||
await page.goto('/admin')
|
||||
|
||||
await page.getByRole('button', { name: /Att göra/ }).click()
|
||||
await page.locator('#admin-order-search').fill(shortOrderId)
|
||||
await openAdminTodoBoard(page)
|
||||
await searchAdminOrders(page, shortOrderId)
|
||||
|
||||
await expectAdminOrderRow(page, {
|
||||
shortOrderId,
|
||||
plate,
|
||||
todo: true,
|
||||
})
|
||||
const row = page.locator('.admin__row', { hasText: shortOrderId })
|
||||
await expect(row).toBeVisible()
|
||||
await expect(row.locator('.admin__order-id')).toHaveText(shortOrderId)
|
||||
await expect(row.locator('.admin__plate')).toHaveText(plate)
|
||||
await expect(row).toHaveClass(/admin__row--todo/)
|
||||
})
|
||||
|
||||
test('admin finds paid order when searching full order id', async ({ page }) => {
|
||||
await loginAsAdmin(page)
|
||||
await page.goto('/admin')
|
||||
|
||||
await page.getByRole('button', { name: /Att göra/ }).click()
|
||||
await page.locator('#admin-order-search').fill(orderId)
|
||||
await openAdminTodoBoard(page)
|
||||
await searchAdminOrders(page, orderId)
|
||||
|
||||
await expectAdminOrderRow(page, { shortOrderId, plate })
|
||||
const row = page.locator('.admin__row', { hasText: shortOrderId })
|
||||
await expect(row).toBeVisible()
|
||||
await expect(row.locator('.admin__order-id')).toHaveText(shortOrderId)
|
||||
await expect(row.locator('.admin__plate')).toHaveText(plate)
|
||||
})
|
||||
|
||||
test('admin finds paid order when searching registration number', async ({
|
||||
page,
|
||||
}) => {
|
||||
await loginAsAdmin(page)
|
||||
await page.goto('/admin')
|
||||
await openAdminTodoBoard(page)
|
||||
await searchAdminOrders(page, plate)
|
||||
|
||||
await page.getByRole('button', { name: /Att göra/ }).click()
|
||||
await page.locator('#admin-order-search').fill(plate)
|
||||
|
||||
const row = page.locator('.admin__row', { hasText: shortOrderId })
|
||||
await expect(row).toBeVisible()
|
||||
await expect(row.locator('.admin__plate')).toHaveText(plate)
|
||||
await expectAdminOrderRow(page, { shortOrderId, plate })
|
||||
})
|
||||
|
||||
test('admin does not show unpaid order under Att göra before payment', async ({
|
||||
|
|
@ -130,14 +151,13 @@ test.describe('Deferred payment and admin lookup', () => {
|
|||
|
||||
await page.evaluate(() => localStorage.clear())
|
||||
await loginAsAdmin(page)
|
||||
await page.goto('/admin')
|
||||
await page.getByRole('button', { name: /Att göra/ }).click()
|
||||
await openAdminTodoBoard(page)
|
||||
|
||||
const unpaidRow = page.locator('.admin__row', { hasText: unpaidShortId })
|
||||
await expect(unpaidRow).not.toBeVisible()
|
||||
|
||||
await page.getByRole('button', { name: /Väntar/ }).click()
|
||||
await page.locator('#admin-order-search').fill(unpaidPlate)
|
||||
await searchAdminOrders(page, unpaidPlate)
|
||||
await expect(unpaidRow).toBeVisible()
|
||||
await expect(unpaidRow.locator('.admin__plate')).toHaveText(unpaidPlate)
|
||||
})
|
||||
|
|
|
|||
Loading…
Reference in a new issue