Playwright 配置文件/运行命令/测试标记

Playwright 配置文件/运行命令/测试标记

一、运行说明

1. 运行命令

js 复制代码
// 运行测试集,无界面模式
npx playwright test

// 运行测试集,界面模式
npx playwright test --ui

// 运行单个测试文件
npx playwright test test_file.spec.ts

// 以调试模式运行测试
npx playwright test --debug

// 显示测试报告
npx playwright show-report

// 运行代码生成器,后可跟需要测试的网站
npx playwright codegen http://baidu.com

// 根据标签运行指定标签下的用例
npx playwright test --grep @fast

2. 配置文件参数

testDir

test 运行的测试文件地址,运行方式为并行

retries

重试次数(根据运行环境判断,本地不重试)

trace

运行跟踪设置,"on-first-retry" 在第一次运行失败时记录。本地运行时默认关闭,可以通过参数 --trace on 打开

baseURL

基础url, 默认打开页面

actionTimeout

动作等待时间

screenshot

失败用例截屏,运行执行失败后,截取屏幕

headless

浏览器运行模式,是否显示浏览器页面

projects

为浏览器配置项目
name: 浏览器信息
use: 设备名称

webServer

启动本地的服务器
command: 服务器启动命令
url: 服务器访问地址
reuseExistingServer: 环境信息判断

其他

二、测试标记

test.only()

仅运行该测试方法下的步骤

ts 复制代码
test.only('仅运行该方法下的测试用例', async ({ page }) => {
  // 仅运行该测试方法在的步骤
});

test.skip()

无条件的跳过该测试用例的执行,可以加到文件中,跳过文件执行,或者添加条件根据条件判断是否跳过

ts 复制代码
// 跳过用例
test('跳过测试用例', async ({ page }) => {
  test.skip();
  // 测试用例的执行步骤
});

// 跳过文件
test.skip();
test('跳过文件 执行', async ( { page } ) ->{
    //测试步骤
})

// 根据条件判断是否跳过
test('根据条件判断是否跳过')

test.slow()

将测试步骤的执行速度放慢三倍,使用方式同 skip

test.step()

拆分测试用例的步骤,将一个测试用例,按照不同的步骤进行执行,步骤中可以继续套步骤

ts 复制代码
test('拆分步骤进行执行', async ( { page } ) => {
    
    await test.step('步骤 1', async ()=>{
        // 具体执行
    })

    await test.step('步骤 2', async ()=>{
        // 具体执行
        await test.step('步骤 2-1', async ()=>{
            // 具体执行
        })
    })

})

test.use()

进行执行文件的测试配置

ts 复制代码
// 使用 chrome 浏览器进行测试
test.use({ browserName: 'chromium' });

test('example test', async ({ page }) => {
  // 测试代码
});

// 可选配置项
1.  browserName :指定要使用的浏览器名称,如  'chromium' 、 'firefox'  或  'webkit' 。 
2.  headless :指定浏览器是否以无头模式运行,接受布尔值,默认为  true 。 
3.  channel :指定要使用的浏览器版本的频道,如  'chrome' 、 'firefox'  或  'webkit' 。 
4.  launchOptions :指定浏览器启动选项的对象,可用于配置浏览器启动时的行为,例如  slowMo 、 args 、 executablePath  等。 
5.  contextOptions :指定上下文选项的对象,可用于配置浏览器上下文的行为,例如  viewport 、 ignoreHTTPSErrors 、 recordVideo  等。 
6.  device :指定要模拟的设备名称,用于测试响应式设计。 
7.  trace :指定要启用的跟踪器的名称,用于记录浏览器操作的详细信息。

test.expect()

创建测试断言,用来判断测试步骤执行后,实际结果是否和预期结果相符

ts 复制代码
test('expect 断言验证', async ({page}) => {
    await page.goto('https://baidu.com/');
    // 进行打开网页操作后,判断页面的标题是否为 百度一下,你就知道
    await expect(page).toHaveTitle(/百度一下,你就知道/);
})
相关推荐
程序员龙叔10 天前
编写高质量 Skill 系列 -- 如何设计需求分析与用例生成的 SKILL
自动化测试·软件测试·python·软件测试工程师·接口测试·性能测试·skill·ai测试
goldenrolan10 天前
A公司物料替代测试系统 v1.7:从需求到 exe/apk 的 AI 辅助全链路实践
android·自动化测试·软件测试·python·ai
程序员小远10 天前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
程序员三藏10 天前
Web自动化测试详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
程序员龙叔11 天前
从 0 开始学习 AI 测试 - 从接口测试来教你如何用 AI 来生成自动化测试代码
自动化测试·软件测试·python·软件测试工程师·测试工具·性能测试·ai测试
深蓝电商API11 天前
移动端浏览器自动化:Playwright for Android 实战
爬虫·playwright
wuhuhuan13 天前
playwright-getByAltText
ui·playwright
开开心心就好13 天前
解决截图被拦截黑屏问题的免费小工具
安全·智能手机·flink·kafka·pdf·音视频·1024程序员节
纳米软件13 天前
CSDN:5G_6G毫米波射频芯片测试,如何解决OTA测试中的“测不准”与“效率低”?
自动化测试·5g·ate测试·ate测试系统·电子测试测量·电子测试工具