javascript - 是否可以在 Playwright 中创建自定义命令?
问题描述
我正在寻找一种在 Playwright 中编写自定义命令的方法,就像在 Cypress中一样。Playwright Issues 有一页与之相关,但我从未见过任何代码示例。
我正在研究一个测试用例,试图提高代码的可重用性。这是代码:
import { test, chromium } from '@playwright/test';
config();
let context;
let page;
test.beforeEach(async () => {
context = await chromium.launchPersistentContext(
'C:\\Users\\User\\AppData\\Local\\Microsoft\\Edge\\User Data\\Default',
{
headless: false,
executablePath: 'C:\\Program Files (x86)\\Microsoft\\Edge\\Application\\msedge.exe',
}
);
page = await context.newPage();
await page.goto('http://localhost:3000/');
});
test.afterEach(async () => {
await page.close();
await context.close();
});
test('Sample test', async () => {
await page.click('text=Open popup');
await page.click('_react=Button >> nth=0');
await page.click('text=Close popup');
});
我正在尝试创建一个函数,该函数将调用钩子 test.beforeEach() 和 test.afterEach() 以及其中的代码。
在剧作家问题页面中,它说我需要将它移动到一个单独的节点模块,然后我才能使用它,但我很难理解如何去做。
解决方案
您提供的示例可以通过实现自定义夹具来解决。Fixtures 是@playwright/test 定制/扩展测试框架的解决方案。您可以定义注入到测试中的自己的对象(类似于浏览器、上下文、页面),以便测试可以访问它。但他们也可以在每次测试之前和之后做一些事情,例如设置先决条件并将其拆除。您还可以覆盖现有的固定装置。
有关包括示例在内的更多信息,请查看此处: https ://playwright.dev/docs/test-fixtures
推荐阅读
- wordpress - 单击 Woocommerce 类别时弹出消息
- google-apps-script - 我在哪里可以找到 G 表导出到 pdf 的选项列表?
- django - django 部署 settings.py 中的更改
- spring - 如何使用spring cloud在k8s中两个服务之间进行通信
- python - 如何在没有数据库的情况下将来自我的个人 API 的数据显示到仪表板?
- reactjs - 使用 react-redux 和 react-aad-msal 登录后如何触发操作?
- html - 如何确定响应式滚动菜单的宽度
- python - request.py 中的 Python 3.7.4 urllib 问题
- r - 如何将列表与数据表合并,同时保持列表格式作为输出
- sql - 在 postgresql 中为 dense_rank 查询建立索引