mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-15 05:37:32 +00:00
Close: [BS-949](https://linear.app/affine-design/issue/BS-949/outline-viewer-加入到affine) Details are in this PR: https://github.com/toeverything/blocksuite/pull/7704
123 lines
4.3 KiB
TypeScript
123 lines
4.3 KiB
TypeScript
import { test } from '@affine-test/kit/playwright';
|
|
import { openHomePage } from '@affine-test/kit/utils/load-page';
|
|
import {
|
|
clickNewPageButton,
|
|
getBlockSuiteEditorTitle,
|
|
waitForEditorLoad,
|
|
} from '@affine-test/kit/utils/page-logic';
|
|
import {
|
|
confirmExperimentalPrompt,
|
|
openExperimentalFeaturesPanel,
|
|
openSettingModal,
|
|
} from '@affine-test/kit/utils/setting';
|
|
import type { Page } from '@playwright/test';
|
|
import { expect } from '@playwright/test';
|
|
|
|
const addDatabase = async (page: Page) => {
|
|
await page.keyboard.press('/', { delay: 500 });
|
|
await page.keyboard.press('d', { delay: 500 });
|
|
await page.keyboard.press('a', { delay: 500 });
|
|
await page.keyboard.press('t', { delay: 500 });
|
|
await page.keyboard.press('a', { delay: 500 });
|
|
await page.getByTestId('Table View').click();
|
|
};
|
|
|
|
test('database is useable', async ({ page }) => {
|
|
test.slow();
|
|
await openHomePage(page);
|
|
await waitForEditorLoad(page);
|
|
await clickNewPageButton(page);
|
|
const title = getBlockSuiteEditorTitle(page);
|
|
await title.pressSequentially('test title');
|
|
await page.keyboard.press('Enter');
|
|
expect(await title.innerText()).toBe('test title');
|
|
await addDatabase(page);
|
|
const database = page.locator('affine-database');
|
|
await expect(database).toBeVisible();
|
|
await page.reload();
|
|
await waitForEditorLoad(page);
|
|
await clickNewPageButton(page);
|
|
const title2 = getBlockSuiteEditorTitle(page);
|
|
await title2.pressSequentially('test title2');
|
|
await page.waitForTimeout(500);
|
|
expect(await title2.innerText()).toBe('test title2');
|
|
await page.keyboard.press('Enter');
|
|
await addDatabase(page);
|
|
const database2 = page.locator('affine-database');
|
|
await expect(database2).toBeVisible();
|
|
});
|
|
|
|
test('link page is useable', async ({ page }) => {
|
|
await openHomePage(page);
|
|
await waitForEditorLoad(page);
|
|
await clickNewPageButton(page);
|
|
await waitForEditorLoad(page);
|
|
const title = getBlockSuiteEditorTitle(page);
|
|
await title.pressSequentially('page1');
|
|
await page.keyboard.press('Enter');
|
|
expect(await title.innerText()).toBe('page1');
|
|
await clickNewPageButton(page);
|
|
await waitForEditorLoad(page);
|
|
const title2 = getBlockSuiteEditorTitle(page);
|
|
await title2.pressSequentially('page2');
|
|
await page.keyboard.press('Enter');
|
|
expect(await title2.innerText()).toBe('page2');
|
|
await page.keyboard.press('@', { delay: 50 });
|
|
await page.keyboard.press('p');
|
|
await page.keyboard.press('a');
|
|
await page.keyboard.press('g');
|
|
await page.keyboard.press('e');
|
|
await page.keyboard.press('1');
|
|
await page.keyboard.press('Enter');
|
|
const link = page.locator('.affine-reference');
|
|
await expect(link).toBeVisible();
|
|
await page.click('.affine-reference');
|
|
await page.waitForTimeout(500);
|
|
|
|
await expect(
|
|
page.locator('.doc-title-container:has-text("page1")')
|
|
).toBeVisible();
|
|
});
|
|
|
|
test('outline viewer is useable', async ({ page }) => {
|
|
await openHomePage(page);
|
|
await waitForEditorLoad(page);
|
|
await clickNewPageButton(page);
|
|
await waitForEditorLoad(page);
|
|
|
|
await openSettingModal(page);
|
|
await openExperimentalFeaturesPanel(page);
|
|
const prompt = page.getByTestId('experimental-prompt');
|
|
await expect(prompt).toBeVisible();
|
|
await confirmExperimentalPrompt(page);
|
|
const settings = page.getByTestId('experimental-settings');
|
|
const enableOutlineViewerSetting = settings.getByTestId(
|
|
'outline-viewer-switch'
|
|
);
|
|
await expect(enableOutlineViewerSetting).toBeVisible();
|
|
await enableOutlineViewerSetting.click();
|
|
await page.waitForTimeout(500);
|
|
await page.getByTestId('modal-close-button').click();
|
|
await page.waitForTimeout(500);
|
|
|
|
const title = getBlockSuiteEditorTitle(page);
|
|
await title.pressSequentially('Title');
|
|
await page.keyboard.press('Enter');
|
|
expect(await title.innerText()).toBe('Title');
|
|
await page.keyboard.type('# ');
|
|
await page.keyboard.type('Heading 1');
|
|
await page.keyboard.press('Enter');
|
|
await page.keyboard.type('## ');
|
|
await page.keyboard.type('Heading 2');
|
|
await page.keyboard.press('Enter');
|
|
|
|
const indicators = page.locator('.outline-heading-indicator');
|
|
await expect(indicators).toHaveCount(2);
|
|
await expect(indicators.nth(0)).toBeVisible();
|
|
await expect(indicators.nth(1)).toBeVisible();
|
|
|
|
const viewer = page.locator('affine-outline-panel-body');
|
|
await indicators.first().hover();
|
|
await expect(viewer).toBeVisible();
|
|
});
|