Playwright学习:怎么正确使用断言?

前言

Playwright中,断言是一个非常重要的角色,它可以帮助我们验证页面行为是否符合预期。但是,官方文档中提供的断言API很多,分类也不明确,对于新手来说,根本没办法记住所有。

所以,本文中,我将带着大家一起,系统的学习Playwright断言API,帮你快速记住。

断言API

Playwright中提供的断言API很多,但是大致可以分为 基本断言、定位器断言、页面断言、接口类断言等,我们来一个个看下。

基本断言

这些是最基础的断言,通常用于验证元素、页面状态等是否符合预期。

相等:

scss 复制代码
比较原始类型(如数字、字符串、布尔值),使用 === 运算符进行比较
expect(1).toBe(1); // Passes

比较对象或数组(包括嵌套的属性或元素), 递归地比较对象或数组的每个值
expect({ foo: "bar" }).toEqual({ foo: "bar" }); // Passes

不相等: 在匹配器前面添加 .not,我们可以预期相反的情况成立:

scss 复制代码
expect(value).not.toEqual(0);  
await expect(locator).not.toContainText('some text');

包含:

scss 复制代码
expect(value).toContain()

模式匹配:

scss 复制代码
// 匹配类/基础类型的任何实例
expect(value).any()  
// 匹配任何东西
expect(value).anything()  
// 数组包含特定元素
expect(value).arrayContaining() 
// 数量大致相等
expect(value).closeTo()  
// 对象包含特定属性
expect(value).objectContaining()  
// 字符串包含子字符串
expect(value).stringContaining()  
// 字符串与正则表达式匹配
expect(value).stringMatching() 
// 字符串与正则表达式匹配
expect(value).toMatch()  
// 对象包含指定的属性
expect(value).toMatchObject()

定位器断言

这些断言主要集中在定位器上,验证元素的状态、属性、样式等与定位器相关的行为。

可见性:

scss 复制代码
// 元素可见
expect(element).toBeVisible();
// 元素不可见
expect(element).toBeHidden();
// 元素在视图中
expect(element).toBeInViewport(); 

状态变化:

scss 复制代码
// 复选框被选中
await expect(locator).toBeChecked();
// 元素已聚焦
await expect(locator).toBeFocused()
// 容器是空的
await expect(locator).toBeEmpty();
// 元素已启用
await expect(locator).toBeEnabled(); //可点

元素内容:

scss 复制代码
// 元素包含文本
await expect(locator).toContainText(/\d messages/);
// 元素与文本匹配
await expect(locator).toHaveText(/Welcome/);
// 输入有一个值
await expect(locator).toHaveValue(/[0-9]/);
// 元素有一个 ID
await expect(locator).toHaveId('lastname');
// 元素具有类属性
await expect(locator).toHaveClass(/selected/);

页面断言

这些断言主要用于验证页面本身的状态,关注整个页面的行为和外观。

scss 复制代码
// 页面有一个 URL
await expect(page).toHaveURL()
// 页面有标题 
await expect(page).toHaveTitle()
// 页面有截图
await expect(page).toHaveScreenshot()

接口断言

这些断言关注页面或应用程序与外部服务的交互,主要用于验证 HTTP 请求的响应。

scss 复制代码
await expect(response).toBeOK();
await expect(response).not.toBeOK();

软断言

以上的断言API,在失败的时候,会导致测试终止执行,所以 Playwright还支持软断言:失败的软断言不会终止测试执行,而是将测试标记为失败。

软断言的使用也很简单,就像这样,使用 .soft

csharp 复制代码
await expect.soft(page.getByTestId('status')).toHaveText('Success');

以上就是 playwright中关于断言的API了,大家可以在实际开发过程中,选择合适的断言API,提高测试的质量和效率,确保你的应用程序的稳定性和可靠性。

相关推荐
北海-cherish21 分钟前
vue中的 watchEffect、watchAsyncEffect、watchPostEffect的区别
前端·javascript·vue.js
2501_915909061 小时前
HTML5 与 HTTPS,页面能力、必要性、常见问题与实战排查
前端·ios·小程序·https·uni-app·iphone·html5
white-persist2 小时前
Python实例方法与Python类的构造方法全解析
开发语言·前端·python·原型模式
新中地GIS开发老师3 小时前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学
Superxpang3 小时前
前端性能优化
前端·javascript·vue.js·性能优化
Rysxt_3 小时前
Element Plus 入门教程:从零开始构建 Vue 3 界面
前端·javascript·vue.js
隐含3 小时前
对于el-table中自定义表头中添加el-popover会弹出两个的解决方案,分别针对固定列和非固定列来隐藏最后一个浮框。
前端·javascript·vue.js
大鱼前端3 小时前
Turbopack vs Webpack vs Vite:前端构建工具三分天下,谁将胜出?
前端·webpack·turbopack
你的人类朋友3 小时前
先用js快速开发,后续引入ts是否是一个好的实践?
前端·javascript·后端