mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-18 14:56:59 +08:00
### TL;DR Add Edgeless shape ai e2e tests. ### What Changed - Add Edgeless shape make it real e2e - Add Edgeless shape generate image e2e - Fix Edgeless generate headings e2e
87 lines
2.9 KiB
TypeScript
87 lines
2.9 KiB
TypeScript
import { loginUser } from '@affine-test/kit/utils/cloud';
|
|
import { expect } from '@playwright/test';
|
|
|
|
import { test } from '../base/base-test';
|
|
|
|
test.describe('AIAction/GenerateAnImageWithText', () => {
|
|
test.beforeEach(async ({ page, utils }) => {
|
|
const user = await utils.testUtils.getUser();
|
|
await loginUser(page, user);
|
|
await utils.testUtils.setupTestEnvironment(page);
|
|
await utils.chatPanel.openChatPanel(page);
|
|
});
|
|
|
|
test('should generate an image for the selected content', async ({
|
|
page,
|
|
utils,
|
|
}) => {
|
|
const { generateImage } = await utils.editor.askAIWithText(page, 'Panda');
|
|
const { answer, responses } = await generateImage();
|
|
await expect(answer.getByTestId('ai-answer-image')).toBeVisible();
|
|
expect(responses).toEqual(new Set(['insert-below']));
|
|
});
|
|
|
|
test('should generate an image for the selected text block in edgeless', async ({
|
|
page,
|
|
utils,
|
|
}) => {
|
|
const { generateImage } = await utils.editor.askAIWithEdgeless(
|
|
page,
|
|
async () => {
|
|
await utils.editor.createEdgelessText(page, 'Panda');
|
|
}
|
|
);
|
|
const { answer, responses } = await generateImage();
|
|
await expect(answer.getByTestId('ai-answer-image')).toBeVisible();
|
|
expect(responses).toEqual(new Set(['insert-below']));
|
|
});
|
|
|
|
test('should generate an image for the selected note block in edgeless', async ({
|
|
page,
|
|
utils,
|
|
}) => {
|
|
const { generateImage } = await utils.editor.askAIWithEdgeless(
|
|
page,
|
|
async () => {
|
|
await utils.editor.createEdgelessNote(page, 'Panda');
|
|
}
|
|
);
|
|
const { answer, responses } = await generateImage();
|
|
await expect(answer.getByTestId('ai-answer-image')).toBeVisible();
|
|
expect(responses).toEqual(new Set(['insert-below']));
|
|
});
|
|
|
|
test('should generate an image for the selected shape in edgeless', async ({
|
|
page,
|
|
utils,
|
|
}) => {
|
|
const { generateImage } = await utils.editor.askAIWithEdgeless(
|
|
page,
|
|
async () => {
|
|
await utils.editor.createShape(page, 'HelloWorld');
|
|
}
|
|
);
|
|
const { answer, responses } = await generateImage();
|
|
await expect(answer.getByTestId('ai-answer-image')).toBeVisible();
|
|
expect(responses).toEqual(new Set(['insert-below']));
|
|
});
|
|
|
|
test('should show chat history in chat panel', async ({ page, utils }) => {
|
|
const { generateImage } = await utils.editor.askAIWithText(page, 'Panda');
|
|
const { answer } = await generateImage();
|
|
const insert = answer.getByTestId('answer-insert-below');
|
|
await insert.click();
|
|
await utils.chatPanel.waitForHistory(page, [
|
|
{
|
|
role: 'action',
|
|
},
|
|
]);
|
|
const { answer: panelAnswer, actionName } =
|
|
await utils.chatPanel.getLatestAIActionMessage(page);
|
|
await expect(
|
|
panelAnswer.getByTestId('generated-image').locator('img')
|
|
).toBeVisible();
|
|
await expect(actionName).toHaveText(/image/);
|
|
});
|
|
});
|