midscene/packages/evaluation/data-generator/generator-headless.spec.ts

159 lines
5.0 KiB
TypeScript
Raw Permalink Normal View History

import { PlaywrightWebPage } from '@midscene/web/playwright';
import { test } from './fixture';
import { generateExtractData, generateTestDataPath } from './utils';
function sleep(time: number) {
return new Promise((resolve) => {
setTimeout(() => {
resolve(0);
}, time);
});
}
test('todo app', async ({ page }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
await page.goto('https://todomvc.com/examples/react/dist/');
// Add data
await page.getByTestId('text-input').click();
await page.keyboard.type('Learn Python');
await page.keyboard.press('Enter');
await page.getByTestId('text-input').click();
await page.keyboard.type('Learn Rust');
await page.keyboard.press('Enter');
await page.getByTestId('text-input').click();
await page.keyboard.type('Learn AI');
await page.keyboard.press('Enter');
await page.getByText('Learn Rust').hover();
await generateExtractData(playwrightPage, generateTestDataPath('todo'));
await page.keyboard.type('Learn English');
await generateExtractData(
playwrightPage,
generateTestDataPath('todo-input-with-value'),
);
});
test('visualstudio code', async ({ page }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
await page.goto('https://code.visualstudio.com/');
await page.waitForLoadState('networkidle');
await generateExtractData(
playwrightPage,
generateTestDataPath('visualstudio'),
);
});
test('github status page', async ({ page }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
await page.setViewportSize({ width: 1920, height: 1080 });
await page.goto('https://www.githubstatus.com/');
await page.waitForLoadState('networkidle');
await sleep(3000);
await generateExtractData(
playwrightPage,
generateTestDataPath('githubstatus'),
);
});
test('antd widget pagination', async ({ page }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
await page.setViewportSize({ width: 1920, height: 1080 });
await page.goto('https://ant.design/components/pagination-cn');
await page.waitForLoadState('networkidle');
await generateExtractData(
playwrightPage,
generateTestDataPath('antd-pagination'),
);
});
test('antd widget - tooltip', async ({ page }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
await page.setViewportSize({ width: 1920, height: 1080 });
await page.goto('https://ant.design/components/tooltip-cn');
await page.waitForLoadState('networkidle');
await generateExtractData(
playwrightPage,
generateTestDataPath('antd-tooltip'),
);
});
test('antd widget - carousel', async ({ page }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
await page.setViewportSize({ width: 1400, height: 1080 });
await page.goto('https://ant.design/components/carousel-cn');
await page.waitForLoadState('networkidle');
await generateExtractData(
playwrightPage,
generateTestDataPath('antd-carousel'),
);
});
test('antd widget - form', async ({ page }) => {
const playwrightPage = new PlaywrightWebPage(page);
await page.setViewportSize({ width: 1400, height: 1080 });
await page.goto(
'https://ant-design.antgroup.com/components/form-cn#form-demo-register',
);
await page.waitForLoadState('networkidle');
await generateExtractData(playwrightPage, generateTestDataPath('antd-form'));
});
test('heytea online order', async ({ page, ai }) => {
2024-09-10 11:21:44 +08:00
const playwrightPage = new PlaywrightWebPage(page);
page.setViewportSize({ width: 400, height: 905 });
await page.goto('https://heyteavivocity.meuu.online/home');
await page.waitForLoadState('networkidle');
// await page.getByText('English').nth(2).click();
await generateExtractData(
playwrightPage,
generateTestDataPath('online_order'),
);
});
test('heytea online order list (zh-cn)', async ({ page, ai }) => {
const playwrightPage = new PlaywrightWebPage(page);
page.setViewportSize({ width: 400, height: 905 });
await page.goto('https://heyteavivocity.meuu.online/home');
await page.evaluate('window.localStorage.setItem("LOCALE", "zh-CN")');
await page.goto('https://heyteavivocity.meuu.online/home');
await page.waitForLoadState('networkidle');
await ai('点击菜单文字');
await ai('向下滚动一屏幕');
await generateExtractData(
playwrightPage,
generateTestDataPath('online_order_list'),
);
});
test('douyin', async ({ page, ai }) => {
const playwrightPage = new PlaywrightWebPage(page);
page.setViewportSize({ width: 1280, height: 800 });
await page.goto(
'https://www.douyin.com/user/MS4wLjABAAAAGBQf_qNRUBcWNSRCZ1o8vP_qGUC58Gsbcy1Bc1AZvfc?from_tab_name=main&modal_id=7409244439434022195&vid=7409244439434022195',
);
await page.locator('.web-login-tab-list__item').nth(1).click();
await generateExtractData(
playwrightPage,
generateTestDataPath('aweme-login'),
);
await page.locator('.douyin-login__close').click();
await page.keyboard.press('ArrowDown');
await page.waitForTimeout(2000);
await generateExtractData(playwrightPage, generateTestDataPath('aweme-play'));
});