playwright的几个小功能
2023-11-02 本文已影响0人
粥一样温柔
一 在自动化测试报告中标注出已提单的问题
type:备注“issue”,或者更多详细内容
describe:可以贴上问题单链接
data:image/s3,"s3://crabby-images/a698b/a698baddb45153d802d8904da3c21252bddcf345" alt=""
注释之后将在报告中展示issue信息
data:image/s3,"s3://crabby-images/9b128/9b1286f9a7b5ae336ae7ad7271b286f94718dc8f" alt=""
二 设置debug选项
在terminal用命令配置debug
data:image/s3,"s3://crabby-images/b1ec2/b1ec20c5399b709a01cd4820cd468f90e8a0aad0" alt=""
命令执行后会分别吊起调试窗口(如下图左侧)和指定的浏览器(右侧)
data:image/s3,"s3://crabby-images/0d783/0d783e5f7ecd5d3d79b8a9d863f0530a11901c16" alt=""
三 soft Assertions
当我们在测试脚本中用expect来执行多个断言,如果前面的断言出现了错误,之后的脚本将无法执行下去
data:image/s3,"s3://crabby-images/860bb/860bb0405dbf687afd325de1e001563e36bb05ad" alt=""
data:image/s3,"s3://crabby-images/a77ba/a77ba32e4675bcac85d7a72a09ebcdd01e6cc1a9" alt=""
为了解决这个问题,我们可以用 expect.soft 来代替expect 执行断言
data:image/s3,"s3://crabby-images/d1ffd/d1ffd93adf91688a70112bedcbe1fb11839d790b" alt=""
data:image/s3,"s3://crabby-images/b660b/b660b480138030fab48edfb5a3bec263a2d6b3aa" alt=""
四 UI Mode
npx playwright test --ui
data:image/s3,"s3://crabby-images/25a4d/25a4d31af238cee242299663609a635f0c476371" alt=""
在terminal 执行命令 npx playwright test ./tests/demo-to-app.spec.ts --ui
将会吊起可是户测试模型
data:image/s3,"s3://crabby-images/260ac/260ac813a30bbafed996f360989240959838f31f" alt=""
五 接口测试
https://www.youtube.com/watch?v=dFLEHJq9iCE&list=PLYDwWPRvXB89caN5PHWDLrXJuyugu5Mg_&index=4
六 mock API requests
1. abort
data:image/s3,"s3://crabby-images/2a6f7/2a6f710f8f474261986faabf666b29a643af278a" alt=""
await page.route('**/*.{png,jpg,jpeg}', route => route.abort());
// Abort based on the request type
await page.route('**/*', route => {
return route.request().resourceType() === 'image' ? route.abort() : route.continue();
});
以下事例是mock掉包含css的请求
data:image/s3,"s3://crabby-images/d7dc7/d7dc76a93cd3247124e11001e0b94af1cc329b0e" alt=""
以豆瓣网页为例
data:image/s3,"s3://crabby-images/26d23/26d2377cd94ef05aafaa752395309c25396424f8" alt=""
data:image/s3,"s3://crabby-images/28367/28367699bd33f24bf8cbff733a4ddcaed4944c02" alt=""
执行结果显示成功,并且已经去掉了css文件
data:image/s3,"s3://crabby-images/10740/10740ef03731fac1a83e49facae6f6103d59edc7" alt=""
2. Fulfill 截取request,并返回自定义response
data:image/s3,"s3://crabby-images/21712/217126750dbb033602752ce5a97424aa60a75b35" alt=""
示例
data:image/s3,"s3://crabby-images/3678e/3678e0a3c303d7cbef5fabaa7f2323f5f18faac2" alt=""
执行之后,查看该接口的response已经被修改
data:image/s3,"s3://crabby-images/e862c/e862c49564ba932f60b7581dee1678b771aa53ee" alt=""
data:image/s3,"s3://crabby-images/ce8c2/ce8c2d5649f738bd71760e24c44f72eb81b13182" alt=""
此外,官网还提供了 截取response并修改的方法
https://playwright.dev/docs/mock#modify-api-responses