mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-17 14:27:02 +08:00
feat(core): new "is journal" page property (#8525)
close AF-1450, AF-1451, AF-14552
This commit is contained in:
122
tests/affine-local/e2e/journal.spec.ts
Normal file
122
tests/affine-local/e2e/journal.spec.ts
Normal file
@@ -0,0 +1,122 @@
|
||||
import { test } from '@affine-test/kit/playwright';
|
||||
import { openHomePage } from '@affine-test/kit/utils/load-page';
|
||||
import { waitForEditorLoad } from '@affine-test/kit/utils/page-logic';
|
||||
import { expect, type Locator, type Page } from '@playwright/test';
|
||||
|
||||
type MaybeDate = string | number | Date;
|
||||
function isSameDay(d1: MaybeDate, d2: MaybeDate) {
|
||||
const date1 = new Date(d1);
|
||||
const date2 = new Date(d2);
|
||||
return (
|
||||
date1.getFullYear() === date2.getFullYear() &&
|
||||
date1.getMonth() === date2.getMonth() &&
|
||||
date1.getDate() === date2.getDate()
|
||||
);
|
||||
}
|
||||
|
||||
function getJournalRow(page: Page) {
|
||||
return page.locator(
|
||||
'[data-testid="doc-property-row"][data-info-id="journal"]'
|
||||
);
|
||||
}
|
||||
async function isJournalEditor(page: Page, maybeDate?: string | number | Date) {
|
||||
// journal header
|
||||
const header = page.getByTestId('header');
|
||||
const weekPicker = header.getByTestId('journal-week-picker');
|
||||
await expect(weekPicker).toBeVisible();
|
||||
|
||||
// journal title
|
||||
const journalTitle = page.getByTestId('journal-title');
|
||||
await expect(journalTitle).toBeVisible();
|
||||
|
||||
if (maybeDate) {
|
||||
const date = (await journalTitle.getByTestId('date').textContent()) ?? '';
|
||||
expect(isSameDay(date, maybeDate)).toBeTruthy();
|
||||
}
|
||||
}
|
||||
async function openPagePropertiesAndAddJournal(page: Page) {
|
||||
const collapse = page.getByTestId('page-info-collapse');
|
||||
const open = await collapse.getAttribute('aria-expanded');
|
||||
if (open?.toLowerCase() !== 'true') {
|
||||
await collapse.click();
|
||||
}
|
||||
|
||||
// add if not exists
|
||||
if ((await getJournalRow(page).count()) === 0) {
|
||||
const addPropertyButton = page.getByTestId('add-property-button');
|
||||
if (!(await addPropertyButton.isVisible())) {
|
||||
await page.getByTestId('property-collapsible-button').click();
|
||||
}
|
||||
await addPropertyButton.click();
|
||||
await page
|
||||
.locator('[role="menuitem"][data-property-type="journal"]')
|
||||
.click();
|
||||
await page.keyboard.press('Escape');
|
||||
}
|
||||
// expand if collapsed
|
||||
else if (!(await getJournalRow(page).isVisible())) {
|
||||
await page.getByTestId('property-collapsible-button').click();
|
||||
}
|
||||
|
||||
const journalRow = getJournalRow(page);
|
||||
await expect(journalRow).toBeVisible();
|
||||
return journalRow;
|
||||
}
|
||||
async function toggleJournal(row: Locator, value: boolean) {
|
||||
const checkbox = row.locator('input[type="checkbox"]');
|
||||
const state = await checkbox.inputValue();
|
||||
const checked = state === 'on';
|
||||
if (checked !== value) {
|
||||
await checkbox.click();
|
||||
const newState = await checkbox.inputValue();
|
||||
const newChecked = newState === 'on';
|
||||
expect(newChecked).toBe(value);
|
||||
}
|
||||
}
|
||||
async function createPageAndTurnIntoJournal(page: Page) {
|
||||
await page.getByTestId('sidebar-new-page-button').click();
|
||||
await waitForEditorLoad(page);
|
||||
const journalRow = await openPagePropertiesAndAddJournal(page);
|
||||
await toggleJournal(journalRow, true);
|
||||
return journalRow;
|
||||
}
|
||||
|
||||
test('Create a journal from sidebar', async ({ page }) => {
|
||||
await openHomePage(page);
|
||||
await page.getByTestId('slider-bar-journals-button').click();
|
||||
await waitForEditorLoad(page);
|
||||
await isJournalEditor(page);
|
||||
});
|
||||
|
||||
test('Create a page and turn it into a journal', async ({ page }) => {
|
||||
await openHomePage(page);
|
||||
await createPageAndTurnIntoJournal(page);
|
||||
await isJournalEditor(page, new Date());
|
||||
});
|
||||
|
||||
test('Should show duplicated tag when create journal on same day', async ({
|
||||
page,
|
||||
}) => {
|
||||
await openHomePage(page);
|
||||
await createPageAndTurnIntoJournal(page);
|
||||
const journalRow2 = await createPageAndTurnIntoJournal(page);
|
||||
await expect(journalRow2.getByTestId('conflict-tag')).toBeVisible();
|
||||
});
|
||||
|
||||
test('Resolve duplicated journal', async ({ page }) => {
|
||||
await openHomePage(page);
|
||||
await createPageAndTurnIntoJournal(page);
|
||||
const journalRow2 = await createPageAndTurnIntoJournal(page);
|
||||
await journalRow2.getByTestId('conflict-tag').click();
|
||||
const journalPanel = page.getByTestId('sidebar-journal-panel');
|
||||
await expect(journalPanel).toBeVisible();
|
||||
const conflictList = journalPanel.getByTestId('journal-conflict-list');
|
||||
await expect(conflictList).toBeVisible();
|
||||
const conflictItems = conflictList.getByTestId('journal-conflict-item');
|
||||
const first = conflictItems.first();
|
||||
await first.getByTestId('journal-conflict-edit').click();
|
||||
await page.getByTestId('journal-conflict-remove-mark').click();
|
||||
|
||||
await expect(journalRow2.getByTestId('conflict-tag')).not.toBeVisible();
|
||||
await expect(conflictList).not.toBeVisible();
|
||||
});
|
||||
@@ -120,6 +120,7 @@ test('property table reordering', async ({ page }) => {
|
||||
|
||||
// new order should be Doc mode, (Tags), Number, Date, Checkbox, Text
|
||||
for (const [index, property] of [
|
||||
'Journal',
|
||||
'Doc mode',
|
||||
'Tags',
|
||||
'Number',
|
||||
@@ -159,6 +160,7 @@ test('page info show more will show all properties', async ({ page }) => {
|
||||
await page.click('[data-testid="property-collapsible-button"]');
|
||||
|
||||
for (const [index, property] of [
|
||||
'Journal',
|
||||
'Doc mode',
|
||||
'Tags',
|
||||
'Text',
|
||||
|
||||
Reference in New Issue
Block a user