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

news2025/4/18 23:31:34

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

一、运行说明

1. 运行命令

// 运行测试集,无界面模式
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()

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

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

test.skip()

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

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

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

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

test.slow()

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

test.step()

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

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

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

})

test.use()

进行执行文件的测试配置

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

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

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

test.expect()

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

test('expect 断言验证', async ({page}) => {
    await page.goto('https://baidu.com/');
    // 进行打开网页操作后,判断页面的标题是否为 百度一下,你就知道
    await expect(page).toHaveTitle(/百度一下,你就知道/);
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1127957.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

选购采购管理软件,首先考虑这5个功能

虽然采购已经达到了数字化的临界点,但企业在接受新的解决方案时却犹豫不决。德勤一份全球首席采购官调查显示,只有 18% 的组织制定了数字化采购战略。 自动化采购任务和优化采购到付款周期可以为企业节省大量金钱和时间。然而,通过过时的采购…

Maven依赖scope为system级别部署时Jar包缺少解决

问题 在开发springboot项目时,maven引入本地第三方jar包,在idea中运行正常。打成jar部署后报找不到类 错误如下: ERROR SpringApplication.reportFailure(834) | Application run failed org.springframework.beans.factory.UnsatisfiedDep…

【tio-websocket】8、服务配置与维护—TioConfig

场景 我们在写 TCP Server 时,都会先选好一个端口以监听客户端连接,再创建N组线程池来执行相关的任务,譬如发送消息、解码数据包、处理数据包等任务,还要维护客户端连接的各种数据,为了和业务互动,还要把这些客户端连接和各种业务数据绑定起来,譬如把某个客户端绑定到一…

仪表盘自定义标题和数值样式

仪表盘自定义标题和数值样式 fn() var myEcharts; function fn(v) {var chartDom document.getElementById(myEcharts);myEcharts&& myEcharts.dispose();myEcharts echarts.init(chartDom, walden);var option;option {series: [{type: gauge,radius: 85%,center: […

activiti7 报错Couldn‘t resolve collection expression nor variable reference

解决方法 nacos添加配置 spring:activiti: serializePOJOsInVariablesToJson: false 截图如下: 分析过程 Couldnt resolve collection expression nor variable reference报错分析是“无法解析集合表达式或变量引用” 刚开始我一直测试…

激光雷达数据为例滤波器

可以通过传感器获取障碍物的位置、速度; 但是任何测量结果都是有误差的。 因此需要在传感器测量结果的基础上, 进行跟踪,以此来保证障碍物的位置、速度等信息不会发生突变。 所谓的跟踪就是通过运动模型来递推障碍物的位置、速度等信息。 最经典的跟踪算法是卡尔曼滤波器。…

用户社交信息交互卡片

效果展示 CSS 知识点 CSS 基础知识回顾transition-delay 属性的运用 整体页面布局实现 <div class"card"><div class"user"><div class"img_box"><img src"bg.jpg" /></div><div class"cont…

积分球检测水质的原理是什么?

积分球可以用于检测水质&#xff0c;主要通过测量水体中物质的吸收光谱来实现。具体来说&#xff0c;光路经过积分球内腔&#xff0c;当水样经过球体时&#xff0c;水体中的物质会吸收一定波长的光&#xff0c;从而改变球体的透射光强。通过测量球体透射光强的改变&#xff0c;…

UE 交互草实现 不通过RT与距离场的方式

通过计算世界场景位置与玩家位置的距离&#xff0c;如果距离大于等于DistanceEffect则不做操作&#xff0c;若小于DistanceEffect则DistanceEffect减去两者之间距离除以并除以DistanceEffect&#xff0c;为什么有这个操作呢&#xff1f; 因为我们要做在DistanceEffect距离内&a…

水质分析仪器升级新功能

水质分析仪器&#xff1a;是一种适用于水质多参数测试的便携式仪器。它具有7英寸的触摸彩色屏幕&#xff0c;用户可以通过触摸屏幕进行操作和查看测试结果。 该仪器主要用于测定COD&#xff0c;氨氮&#xff0c;总磷&#xff0c;总氮等常规水质指标&#xff0c;pH值、溶解氧、…

CTFhub-SSRF-端口扫描

根据提示&#xff1a; 来来来性感CTFHub在线扫端口,据说端口范围是8000-9000哦, 用数字生成器生成 8000-9000 的数字 在线生成1到10000阿拉伯数字 - 批量之家 通过 burp 抓包爆破 爆破需要在 url 后添加 127.0.0.1&#xff1a; 根据爆破结果&#xff0c;端口是 8335

【EI会议征稿】第五届大数据与信息化教育国际学术会议(ICBDIE 2024)

【有往届检索记录】第五届大数据与信息化教育国际学术会议&#xff08;ICBDIE 2024&#xff09; 2023 5th International Conference on Big Data and Informatization Education 第五届大数据与信息化教育国际学术会议&#xff08;ICBDIE 2024&#xff09;定于2024年01月19-…

记录npm的版本问题

安装vivo小游戏开发者工具时&#xff0c;运行mg -v时出现错误&#xff0c;错误的原因是node.js的的版本过低&#xff0c;我用的是6.11.2&#xff0c;将node.js升级到10.10.0问题解决

别处拿来的VUE项目 npm run serve报错

问题现象&#xff1a; 从别处拷贝来的VUE项目&#xff0c;根据说明通过npm install 加载了项目依赖 &#xff0c;但是运行npm run serve里报错&#xff1a; npm ERR! Missing script: "serve" npm ERR! npm ERR! To see a list of scripts, run: npm ERR! npm ru…

Mr.Alright---MTK安卓13 抬手亮屏功能的逻辑

该功能在系统设置-显示-拿起设备时唤醒 alps\vendor\mediatek\proprietary\packages\apps\MtkSettings\src\com\android\settings\display\LiftToWakePreferenceController.javapublic boolean isAvailable() {SensorManager sensors (SensorManager) mContext.getSystemServ…

应用系统集成-企业集成模式(EIP)

应用系统集成-企业集成模式&#xff08;EIP&#xff09; 无论是系统间集成或是系统内部组件之间通讯&#xff0c;消息&#xff08;信息流&#xff09;都是系统设计最重要的因素。EIP将详细的讲述了从消息的角度进行集成设计考虑方方面面&#xff0c;是系统设计重要的参考资料。…

springBoot与Vue共同搭建webSocket环境

欢迎使用Markdown编辑器 你好&#xff01; 这片文章将教会你从后端springCloud到前端VueEleementAdmin如何搭建Websocket 前端 1. 创建websocket的配置文件在utils文件夹下websocket.js // 暴露自定义websocket对象 export const socket {// 后台请求路径url: ,websocketCo…

Python学习--函数传值问题

四、函数传值问题 先看一个例子&#xff1a; # -*- coding: UTF-8 -*- def chagne_number( b ):b 1000b 1 chagne_number(b) print( b )最后输出的结果为&#xff1a; 1先看看运行的结果&#xff1f; 想一下为什么打印的结果是 1 &#xff0c;而不是 1000 &#xff1f; …

凉鞋的 Godot 笔记 204. 语句

204. 语句 在上一篇&#xff0c;我们接触了三种常见的类型&#xff0c;如下所示&#xff1a; 这样我们算是对变量进行了一个入门了。 其实我们除了变量&#xff0c;我们还接触了一个叫做语句的概念。 我们可以看下代码: extends Node# Called when the node enters the sce…

Kubernetes原生微服务开发实践

&#x1f482; 个人网站:【工具大全】【游戏大全】【神级源码资源网】&#x1f91f; 前端学习课程&#xff1a;&#x1f449;【28个案例趣学前端】【400个JS面试题】&#x1f485; 寻找学习交流、摸鱼划水的小伙伴&#xff0c;请点击【摸鱼学习交流群】 引言 随着互联网业务的…