mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-26 10:45:57 +08:00
test(editor): add embed iframe block e2e tests (#11502)
Close [BS-2669](https://linear.app/affine-design/issue/BS-2669/iframe-embed-block-添加测试)
This commit is contained in:
262
tests/affine-local/e2e/blocksuite/embed/embed-iframe.spec.ts
Normal file
262
tests/affine-local/e2e/blocksuite/embed/embed-iframe.spec.ts
Normal file
@@ -0,0 +1,262 @@
|
||||
import {
|
||||
clickEdgelessModeButton,
|
||||
locateEditorContainer,
|
||||
locateToolbar,
|
||||
} from '@affine-test/kit/utils/editor';
|
||||
import { openHomePage } from '@affine-test/kit/utils/load-page';
|
||||
import {
|
||||
clickNewPageButton,
|
||||
type,
|
||||
waitForEmptyEditor,
|
||||
} from '@affine-test/kit/utils/page-logic';
|
||||
import { expect, type Page, test } from '@playwright/test';
|
||||
|
||||
const TEST_SPOTIFY_URL =
|
||||
'https://open.spotify.com/episode/7makk4oTQel546B0PZlDM5';
|
||||
|
||||
const TEST_AFFINE_URL = 'https://affine.pro/';
|
||||
|
||||
const EMBED_IFRAME_BLOCK = 'affine-embed-iframe-block';
|
||||
const EMBED_EDGELESS_IFRAME_BLOCK = 'affine-embed-edgeless-iframe-block';
|
||||
const IDLE_CARD = 'embed-iframe-idle-card';
|
||||
const LOADING_CARD = 'embed-iframe-loading-card';
|
||||
const LINK_INPUT_POPUP = 'embed-iframe-link-input-popup';
|
||||
|
||||
test.beforeEach(async ({ page }) => {
|
||||
await openHomePage(page);
|
||||
await clickNewPageButton(page);
|
||||
await waitForEmptyEditor(page);
|
||||
await page.locator('affine-paragraph v-line div').click();
|
||||
});
|
||||
|
||||
test.describe('embed iframe block', () => {
|
||||
async function addEmbedIframeBlock(page: Page) {
|
||||
await type(page, '/embed');
|
||||
const embedItem = page.getByTestId('Embed');
|
||||
await embedItem.click();
|
||||
|
||||
const embedIframeBlock = page.locator(EMBED_IFRAME_BLOCK);
|
||||
await expect(embedIframeBlock).toBeVisible();
|
||||
|
||||
const embedIframeIdleCard = page.locator(IDLE_CARD);
|
||||
await expect(embedIframeIdleCard).toBeVisible();
|
||||
|
||||
const embedIframeLinkInputPopup = page.locator(LINK_INPUT_POPUP);
|
||||
await expect(embedIframeLinkInputPopup).toBeVisible();
|
||||
|
||||
const input = embedIframeLinkInputPopup.locator('input');
|
||||
await expect(input).toBeFocused();
|
||||
|
||||
return {
|
||||
embedIframeBlock,
|
||||
embedIframeIdleCard,
|
||||
embedIframeLinkInputPopup,
|
||||
input,
|
||||
};
|
||||
}
|
||||
|
||||
async function openToolbarAndSwitchView(page: Page) {
|
||||
// expect toolbar to be visible
|
||||
const toolbar = locateToolbar(page);
|
||||
await expect(toolbar).toBeVisible();
|
||||
|
||||
// switch to inline view
|
||||
await page.getByRole('button', { name: 'Switch view' }).click();
|
||||
}
|
||||
|
||||
test('add embed iframe block using slash menu', async ({ page }) => {
|
||||
const {
|
||||
embedIframeBlock,
|
||||
embedIframeIdleCard,
|
||||
embedIframeLinkInputPopup,
|
||||
input,
|
||||
} = await addEmbedIframeBlock(page);
|
||||
|
||||
await input.fill(TEST_SPOTIFY_URL);
|
||||
await input.press('Enter');
|
||||
await page.waitForTimeout(100);
|
||||
|
||||
await expect(embedIframeLinkInputPopup).not.toBeVisible();
|
||||
await expect(embedIframeIdleCard).not.toBeVisible();
|
||||
|
||||
// expect the embed iframe block count is 1
|
||||
await expect(embedIframeBlock).toHaveCount(1);
|
||||
});
|
||||
|
||||
test('add bookmark when the url cannot be embedded', async ({ page }) => {
|
||||
const {
|
||||
embedIframeBlock,
|
||||
embedIframeIdleCard,
|
||||
embedIframeLinkInputPopup,
|
||||
input,
|
||||
} = await addEmbedIframeBlock(page);
|
||||
|
||||
await input.fill(TEST_AFFINE_URL);
|
||||
await input.press('Enter');
|
||||
|
||||
await expect(embedIframeLinkInputPopup).not.toBeVisible();
|
||||
await expect(embedIframeIdleCard).not.toBeVisible();
|
||||
|
||||
// expect the embed iframe block count is 0
|
||||
await expect(embedIframeBlock).toHaveCount(0);
|
||||
|
||||
// expect the bookmark block count is 1
|
||||
const bookmarkBlock = page.locator('affine-bookmark');
|
||||
await expect(bookmarkBlock).toHaveCount(1);
|
||||
});
|
||||
|
||||
test('add embed iframe url by clicking the idle card', async ({ page }) => {
|
||||
const { embedIframeIdleCard, embedIframeLinkInputPopup, input } =
|
||||
await addEmbedIframeBlock(page);
|
||||
// click somewhere else to close the link input popup
|
||||
// click position below the popup
|
||||
const popupBoundingBox = await embedIframeLinkInputPopup.boundingBox();
|
||||
expect(popupBoundingBox).not.toBeNull();
|
||||
if (!popupBoundingBox) return;
|
||||
await page.mouse.click(popupBoundingBox.x - 50, popupBoundingBox.y + 100);
|
||||
await page.waitForTimeout(100);
|
||||
|
||||
await expect(embedIframeLinkInputPopup).not.toBeVisible();
|
||||
|
||||
// click the idle card
|
||||
await embedIframeIdleCard.click();
|
||||
await expect(embedIframeLinkInputPopup).toBeVisible();
|
||||
|
||||
// fill the url
|
||||
await input.fill(TEST_SPOTIFY_URL);
|
||||
await input.press('Enter');
|
||||
|
||||
await expect(embedIframeLinkInputPopup).not.toBeVisible();
|
||||
await expect(embedIframeIdleCard).not.toBeVisible();
|
||||
|
||||
const embedIframeLoadingCard = page.locator(LOADING_CARD);
|
||||
await expect(embedIframeLoadingCard).toBeVisible();
|
||||
});
|
||||
|
||||
test.describe('conversions', () => {
|
||||
async function setupEmbedIframe(page: Page) {
|
||||
const { embedIframeBlock, input } = await addEmbedIframeBlock(page);
|
||||
|
||||
// fill the url
|
||||
await input.fill(TEST_SPOTIFY_URL);
|
||||
await input.press('Enter');
|
||||
|
||||
// wait until iframe is loaded
|
||||
await expect(embedIframeBlock).toBeVisible();
|
||||
|
||||
// click to select embed iframe block
|
||||
await embedIframeBlock.click();
|
||||
|
||||
return { embedIframeBlock };
|
||||
}
|
||||
|
||||
test('embed iframe block to link text', async ({ page }) => {
|
||||
const { embedIframeBlock } = await setupEmbedIframe(page);
|
||||
|
||||
await openToolbarAndSwitchView(page);
|
||||
await page.getByRole('button', { name: 'Inline view' }).click();
|
||||
|
||||
const affineLink = page.locator('affine-link');
|
||||
await expect(affineLink).toBeVisible();
|
||||
|
||||
// hover affine link
|
||||
await affineLink.hover();
|
||||
await page.waitForTimeout(100);
|
||||
|
||||
// convert back to embed iframe block
|
||||
await openToolbarAndSwitchView(page);
|
||||
await page.getByRole('button', { name: 'Embed view' }).click();
|
||||
|
||||
// expect the embed iframe block count is 1
|
||||
await expect(embedIframeBlock).toHaveCount(1);
|
||||
|
||||
// expect the link text content is the url
|
||||
await expect(affineLink).toHaveCount(0);
|
||||
});
|
||||
|
||||
test('embed iframe block to bookmark card', async ({ page }) => {
|
||||
const { embedIframeBlock } = await setupEmbedIframe(page);
|
||||
|
||||
await openToolbarAndSwitchView(page);
|
||||
await page.getByRole('button', { name: 'Card view' }).click();
|
||||
|
||||
// expect the embed iframe block count is 0
|
||||
await expect(embedIframeBlock).toHaveCount(0);
|
||||
|
||||
// expect the bookmark block count is 1
|
||||
const bookmarkBlock = page.locator('affine-bookmark');
|
||||
await expect(bookmarkBlock).toHaveCount(1);
|
||||
|
||||
// click the bookmark block
|
||||
await bookmarkBlock.click();
|
||||
|
||||
// convert back to embed iframe block
|
||||
await openToolbarAndSwitchView(page);
|
||||
await page.getByRole('button', { name: 'Embed view' }).click();
|
||||
|
||||
// expect the embed iframe block count is 1
|
||||
await expect(embedIframeBlock).toHaveCount(1);
|
||||
await expect(bookmarkBlock).toHaveCount(0);
|
||||
});
|
||||
});
|
||||
|
||||
test.describe('edgeless mode', () => {
|
||||
// add embed iframe block to edgeless mode by cmdk menu
|
||||
async function addEmbedEdgelessIframeBlock(page: Page) {
|
||||
// switch to edgeless mode
|
||||
await clickEdgelessModeButton(page);
|
||||
const container = locateEditorContainer(page);
|
||||
await container.click();
|
||||
|
||||
// press @ to trigger the menu
|
||||
await page.keyboard.press('@');
|
||||
|
||||
// type spotify url
|
||||
await page.keyboard.type(TEST_SPOTIFY_URL);
|
||||
|
||||
// click item which data-testid='cmdk-label'
|
||||
await page
|
||||
.locator(
|
||||
`[data-testid="cmdk-label"][data-value="external-link:${TEST_SPOTIFY_URL}"]`
|
||||
)
|
||||
.click();
|
||||
|
||||
// expect the embed iframe block count is 1
|
||||
const embedEdgelessIframeBlock = page.locator(
|
||||
EMBED_EDGELESS_IFRAME_BLOCK
|
||||
);
|
||||
await expect(embedEdgelessIframeBlock).toHaveCount(1);
|
||||
}
|
||||
|
||||
test('insert embed iframe block to edgeless directly', async ({ page }) => {
|
||||
await addEmbedEdgelessIframeBlock(page);
|
||||
});
|
||||
|
||||
test('convert between embed view and card view', async ({ page }) => {
|
||||
await addEmbedEdgelessIframeBlock(page);
|
||||
|
||||
await openToolbarAndSwitchView(page);
|
||||
await page.getByRole('button', { name: 'Card view' }).click();
|
||||
|
||||
// expect the embed iframe block count is 0
|
||||
const embedEdgelessIframeBlock = page.locator(
|
||||
EMBED_EDGELESS_IFRAME_BLOCK
|
||||
);
|
||||
await expect(embedEdgelessIframeBlock).toHaveCount(0);
|
||||
|
||||
// expect the bookmark block count is 1
|
||||
const bookmarkEdgelessBlock = page.locator('affine-edgeless-bookmark');
|
||||
await expect(bookmarkEdgelessBlock).toHaveCount(1);
|
||||
|
||||
// click the bookmark block
|
||||
await bookmarkEdgelessBlock.click();
|
||||
|
||||
// convert back to embed view
|
||||
await openToolbarAndSwitchView(page);
|
||||
await page.getByRole('button', { name: 'Embed view' }).click();
|
||||
|
||||
// expect the embed iframe block count is 1
|
||||
await expect(embedEdgelessIframeBlock).toHaveCount(1);
|
||||
});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user