62 lines
2.3 KiB
TypeScript
62 lines
2.3 KiB
TypeScript
import { test, expect } from '@playwright/test';
|
|
import { login, verifyCreateUser, todate } from './util';
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
await login(page);
|
|
await verifyCreateUser(page, { names: ['Test Testerson'] });
|
|
await expect(page.locator('#alpine-loaded')).not.toHaveAttribute('x-cloak');
|
|
});
|
|
|
|
test('manual-freshen date is editable', async ({ page }) => {
|
|
await page.getByRole('link', { name: /edit/i }).click();
|
|
await expect(page.getByRole('textbox', { name: /freshened/i })).toBeVisible();
|
|
});
|
|
|
|
test('last-contact date on display resolves journal mentions and manual-freshen', async ({ page }) => {
|
|
const today = new Date().toISOString().split("T")[0];
|
|
const todayRe = new RegExp(today.substring(0, today.length - 1) + ".");
|
|
const entryDate = page.getByPlaceholder(todayRe);
|
|
const entryBox = page.getByPlaceholder(/new entry/i);
|
|
await entryDate.fill("2025-05-05");
|
|
await entryBox.fill("[[Test Testerson]]");
|
|
await page.getByRole('button', { name: /add entry/i }).click();
|
|
await page.reload();
|
|
await expect(page.locator('#fields')).toContainText("freshened2025-05-05");
|
|
});
|
|
|
|
test.skip("groups wrap nicely", async ({ page }) => {
|
|
await page.getByRole('link', { name: /edit/i }).click();
|
|
await expect(page.locator('#alpine-loaded')).not.toHaveAttribute('x-cloak');
|
|
|
|
const groupBox = page.getByPlaceholder(/group name/i);
|
|
await groupBox.fill('this is a long group name');
|
|
await page.getByRole('button', { name: /save/i }).click();
|
|
await expect(page.locator('#alpine-loaded')).not.toHaveAttribute('x-cloak');
|
|
|
|
// TODO: this drives to the right location but i can't figure out how to assert
|
|
// that the text is all on one line. Manual inspection looks good at time of writing.
|
|
});
|
|
|
|
test('allow marking as hidden', async ({ page }) => {
|
|
|
|
});
|
|
|
|
test('allow exempting from stale', async ({ page }) => {
|
|
|
|
});
|
|
|
|
test('bullet points in free text display well', async ({ page }) => {
|
|
|
|
});
|
|
|
|
twst('page title has contact primary name', async ({ page }) => {
|
|
await expect(page.title()).toContain("Test Testerson");
|
|
});
|
|
|
|
/*
|
|
home: contact list scrolls in screen, not off screen
|
|
home: clicking off contact list closes it
|
|
home: contact list is sorted ignoring case
|
|
home: contact list should scroll to current contact in center of view
|
|
journal: bullet points don't display
|
|
*/
|