首页 > 其他分享 >UI自动化测试工程实践

UI自动化测试工程实践

时间:2024-04-25 17:02:32浏览次数:28  
标签:Playwright 浏览器 py UI 测试 自动化 test page

注:本文档所有操作均基于macOS系统。

1 项目背景
当前IT项目的测试工作主要采用接口自动化及手工操作两种方式,其中手工测试方式耗时长、易出错,而且界面验证还依赖人工进行操作。基于此,我们考虑引入相应的UI自动化测试工具进行辅助测试。通过将稳定的项目功能实现UI自动化,可以提高测试回归验证的效率和准确性。

借此次工具调研的契机,我们将工具用于场地系统,以评估工具对项目带来的测试价值和效率提升情况。

2 UI自动化工具对比
​当前比较流行的UI自动化工具有Playwright和Selenium,它们都拥有丰富的功能和API,适用于测试Web应用程序。我们可以根据不同的需求和场景,选择合适的自动化测试工具。以下是这两个工具的对比情况:

基于上述的对比项,不难看出:

Playwright相对容易学习,对使用人员的技术要求较低。
Playwright的录制生成脚本功能可以显著提高UI自动化实现的效率。
Playwright提供的功能更加全面,执行效率更高。
Playwright拥有更突出的性能优势。
因此,在本次项目实践中,我们选用的是更加简单容易的Playwright。

3 Playwright+ Pytest实战
注:本项目实践基于场地系统进行。

3.1 前置准备
python 3.7+
python三方库Playwright(pip install playwright)
playwright浏览器驱动安装(python -m playwright install)

注:下载资源缓慢请更换pip源为国内源

3.2 项目架构
codegen_data:录制的脚本存放。
common:公用方法存放。
data:测试数据存放。
log:脚本运行产生的日志存放。
test_case:测试用例脚本存放。
test_report:测试报告存放。
config.py:命令/路径等配置信息文件。
conftest.py:setup执行的操作存放。
myRunner.py:执行main。

3.3 录制脚本
① PC端实操

命令行工具执行命令:

python -m playwright codegen -o 'test_login.py' --target python -b chromium https://cas-test.bgyfw.com/idp/authcenter/ActionAuthChain?entityId=BIZTEST

让我们一起解读一下命令的意图:

使用当前计算机的Chromium打开指定URL,生成的脚本语言为python,保存名称为test_login.py。

以上为命令执行后进入的界面,可以发现:

当鼠标滑过元素的时候,会自动提示元素的xpath。

启动的是无痕浏览模式,可以很容易和本地浏览的页面进行区分。
同时也会打开一个Playwright Inspector的窗口,显示生成的代码,以便对页面进行实时操作。
关闭浏览器时,将停止录制并输出脚本文件。从这里可以看出,脚本文件正是上述命令中指定的文件名。这里使用的是同步模式,生成源码如下所示:

点击查看代码
from playwright.sync_api import Playwright, sync_playwright, expectdef run(playwright: Playwright) -> None:
    browser = playwright.chromium.launch(headless=False)
    context = browser.new_context()
    page = context.new_page()
    page.goto("https://cas-test.bgyfw.com/idp/authcenter/ActionAuthChain?entityId=BIZTEST")
    page.goto("https://open-test.bgyfw.com/gateway.html")
    page.goto("https://open-test.bgyfw.com/%E6%93%8D%E4%BD%9C%E6%88%90%E5%8A%9F")
    page.goto("https://cas-test.bgyfw.com/idp/authcenter/ActionAuthChain?entityId=BIZTEST")
    page.get_by_role("img").first.click()
    page.close()    # ---------------------
    context.close()
    browser.close()with sync_playwright() as playwright:
    run(playwright)
生成的代码可以直接运行,运行后会自动打开Chromium浏览器执行相应的页面操作: ![](/i/l/?n=24&i=blog/3423524/202404/3423524-20240425164019482-2014520016.jpg)

到这里我们有一个疑问:Playwright是否支持主流的浏览器?我们如何切换到浏览器?

让我们再次查看执行的命令,发现其中有一个参数【-b】,用于指定浏览器。再看看说明:

-b, --browserbrowser to use, one of cr, chromium, ff, firefox, wk, webkit (default: "chromium")

从上述说明中可以看到,参数【-b】支持Google Chrome、Microsoft Edge(cr,chromium)、 WebKit内核的Apple Safari ( wk, webkit)和 Mozilla Firefox(ff,firefox)浏览器。

让我们基于每一个浏览器都录制生成一份代码:


chrome浏览器


firefox浏览器


Safari浏览器

我们可以发现不同的浏览器在操作上是相似的,生成的代码有一个地方有所不同,如上图红框所示。换个角度来说,我们只需要基于一个浏览器生成代码后,手动修改就能实现浏览器兼容测试和代码的复用,极大地提升了效率。

② 移动端网页实操

命令行工具执行命令:

python -m playwright codegen -o 'test_login.py' --target python -b chromium --device="iPhone 12 Pro" https://cas-test.bgyfw.com/idp/authcenter/ActionAuthChain?entityId=BIZTEST

对比PC端实操执行的命令,当前命令多入参了一个参数【--device】

让我们一起解读一下命令的意图:

模拟iPhone 12 Pro设备打开指定URL,使用Chromium驱动,生成的代码语言设置为python,保存名称为test_login.py。

以上为命令执行后进入的界面,可以发现录制的界面与iPhone 12 Pro打开的网页一致。这不禁让我们产生了一个想法:项目的手机界面兼容测试是不是可以通过Playwright解决?

答案是可以的!

Playwright支持的手机/平板型号共有116种,基本覆盖了50%左右的主流设备,具体如下图所示:


让我们抽几个手机型号录制各生成一份代码:


iPhone 12 Pro


Galaxy S9+


Nexus 7

我们可以发现,不同的手机在相同的操作下,生成的代码只有两行不同,如上图红框所示。

换个角度来说,我们只需要基于一个手机型号生成代码后,手动修改一下就能实现手机浏览器兼容测试和代码的复用,这将大大提升效率。

3.4 conftest应用
在pytest中,除了提供现成的setup和teardown方法,还提供了conftest文件结合fixture的方法来处理测试用例的前置条件和后置条件的操作。

conftest简介:conftest是一个固定的py文件,修改为其他名字不会生效。

conftest作用域:作用范围在该目录及其下的子目录。
conftest作用:同目录下的测试用例文件运行前都会执行conftest.py文件,相当于一个前置文件。
conftest实际应用如下图所示:

对比生成的两个脚本,发现前置的步骤均一致,我们可以把一致的部分提取出来做成setup。

同时,根据conftest文件的作用,我们把前置操作在conftest.py用方法封装起来,如下图所示:

封装完成后对脚本进行简化处理。简化效果如下图所示:

从简化效果来看,可以发现conftest.py文件是不需要导入的,它在执行pytest的时候会自动查找并使用conftest.py文件。

3.5 断言运用

断言当前页面的标题是否是指定的页面标题

expect(page).to_have_title("碧桂园服务统一认证")

expect(page).to_have_title("增值平台")

断言元素是否存在当前页面

assert page.wait_for_selector('#app > section > div.layout-container > section > div > h4')

断言当前元素的文本是否跟预期一致

content = page.text_content('#app > section > div.layout-container > section > div > h4')

assert content == "欢迎使用社区资源管理平台~"

断言元素的文本是否是期望值

js_content = page.locator('#app > section > div.left-menu.wujie-left-menu > div > ul > div:nth-child(3) > li > div > span').text_content()

assert js_content == "客户管理"

断言点击复选框后,复选框为选中状态

page.locator("selector").first.click()

checked = page.is_checked('selector')

assert checked

断言点击取消选择后,复选框为空状态

page.get_by_role("button", name="取消选择").click()

checked = page.is_checked('selector')

assert checked == False

断言按钮原始状态为非激活状态

enabled = page.is_enabled('selector')

assert enabled == False

断言输入内容后,按钮状态变为激活状态

page.get_by_label("新增客户", exact=True).get_by_placeholder("请输入客户税号").click()

page.get_by_label("新增客户", exact=True).get_by_placeholder("请输入客户税号").fill("test")

enabled = page.is_enabled('selector')

assert enabled

3.6 批量执行生成测试报告
生成的测试脚本加上断言后,需要批量执行测试脚本并生成测试报告。

在给出的项目架构中,可以通过配置文件来控制需要执行的测试范围。

首先,在项目中的common/config.py中已经定义了测试用例的路径(case_path)为项目中的test_case文件夹。具体如下图所示:

然后,在项目根目录config.py文件中定义了一个名为cases_path的变量,该变量可用于指定具体的测试范围。我们可以选择定义一个文件夹,以便在执行的时候运行该文件夹下的所有测试脚本;或者指定一个py文件以进行单独执行。具体如下图所示:

最后,配置好测试范围后,可以开始执行测试。在项目根目录myRunner.py文件中,点击运行按钮即可批量执行测试并生成测试报告。


3.7 失败截图定位问题
如果用例执行失败了,要如何进行定位?

根据报告提供的失败截图功能,可以在生成的报告中看到相应的截图和报错信息,帮助我们快速定位问题并进行分析。

4 项目应用取得的成果
场地系统共有数千条测试用例,使用Playwright后,大部分测试用例实现了UI自动化,整体自动化率得到大幅提升。

随着Playwright的使用,场地项目的自动化率不断提高,测试的回归效率也在不断地提升。

注:上图为项目自动化工程脚本树部分截图

5 总结

  1. Playwright是一个功能强大的自动化工具,可用于测试和浏览器兼容。它提供了丰富的功能,可以大大提高测试和自动化的效率和可靠性。

  2. Playwright的录制生成脚本功能解决了测试人员编写操作步骤代码的问题,通过精准的定位,测试人员只需要专注于如何断言即可。相比传统的纯代码,它极大地提升了效率并降低了对测试人员的代码能力要求。

  3. Playwright还解决了UI自动化脚本维护的难题,只需重新录制一份脚本、编排断言并移除旧的脚本即可实现维护。

  4. 此外,Playwright还提供了许多适用于自动化的功能,只有在实践中才能更好地发挥其作用。

标签:Playwright,浏览器,py,UI,测试,自动化,test,page
From: https://www.cnblogs.com/bkyfw/p/18158080

相关文章

  • 使用ansible-playbook自动化安装Oracle DG数据库19c
    【用剧本安装OracleDG数据库】源库是RAC,安装的话可以参考之前内容,目标库DG是单机文件系统说明:源库是RAC架构,DG是单机文件系统架构,管理使用dgbroker管理(这里使用命令行操作),安装单机数据库然后使用createDuplicateDB方式创建DG库,由于剧本脚本较多,可以留言发送脚本所有剧本目录信......
  • 安全测试之探索windows游戏扫雷
    扫雷游戏相信很多人都从小玩过,在那个电脑游戏并不多的时代,扫雷成为玩的热度蛮高的一款游戏之一,然而就在有一次,接触到了一次不寻常的扫雷过程,使得后来我也有了这个冲动,也来做一次。通过动态调试,逆向和来写一个扫雷辅助工具从而提高逆向与编码技能。动态调试(分析)首先进行扫雷程......
  • Python GUI开发- Qt Designer环境搭建
    前言QtDesigner是PyQt5程序UI界面的实现工具,使用QtDesigner可以拖拽、点击完成GUI界面设计,并且设计完成的.ui程序可以转换成.py文件供python程序调用环境准备使用pip安装pipinstallpyqt5-toolsQtDesigner环境搭建在pip安装包的路径中,找到designer.exe文件......
  • VUE配置proxy代理、开发环境、测试环境、生产环境
    1、根目录下新建三个环境的配置文件,.env.development(开发环境).env.test(测试环境).evn.production(生产环境)开发环境NODE_ENV='development'开发环境,api前缀VUE_APP_BASE_API='/api'开发环境,Url地址VUE_APP_BASE_RUL='http://xxxxxxxxxxxxx:8081/****生产环境NODE_ENV......
  • Avalonia UI 中 Styles 与 ControlTheme 的区别
    目录目录介绍使用方式全局主题(GlobalTheme)局部主题(LocalTheme)控件主题(ControlTheme)问题描述问题分析问题1区别问题2重写Template用Styles还是ControlTheme?使用ControlTheme最佳实践总结Style&ControlTheme的特性独立性继承性......
  • 渗透测试(Penetration Testing)是一项针对企业或组织的信息系统安全性的重要评估手段
    渗透测试(PenetrationTesting)是一项针对企业或组织的信息系统安全性的重要评估手段。它模拟黑客的攻击行为,通过利用各种攻击技术和策略,试图非法访问、窃取或破坏目标系统的数据,从而发现系统中可能存在的安全漏洞。渗透测试不仅可以帮助企业识别潜在的安全风险,还能为企业提供关于......
  • 基于北京迅为iTOP-RK3588大语言模型部署测试
     人工智能(AI)领域中的大模型(LargeModel)逐渐成为研究的热点。大模型,顾名思义,是指拥有海量参数和高度复杂结构的深度学习模型。它的出现,不仅推动了AI技术的突破,更为各行各业带来了革命性的变化。RK3588是瑞芯微推出的新一代旗舰级高端处理器,采用8nm工艺设计,搭载四核A76+四核A55的......
  • ansible相比shell脚本自动化有什么优势
    Ansible自动化与Shell脚本自动化相比,具有以下几个显著的优势:轻量级与无需代理:Ansible的一个关键优势在于其轻量级和无需在被控制服务器上安装任何代理或客户端的特点。这极大地简化了部署和维护的流程,降低了复杂性和出错的可能性。而Shell脚本通常需要在每台服务器上单独执行,这......
  • 没有对应芯片手册,不知道哪些IO口可以控,测试demo
     //sdk\apps\earphone\include\app_config.h//////////↓↓↓↓↓↓↓↓↓↓codesnippetfromxwh↓↓↓↓↓↓↓↓↓↓////////////////////#defineLED0_IOIO_PORTA_01#defineLED0_ONOFF(x)do{gpio_set_pull_down(LED0_IO,0);\gpio_set......
  • 「案例分享」DevExpress XAF (WinForms UI)赋能医疗管理系统,让操作更自动化!
    DevExpressXAF是一款强大的现代应用程序框架,它采用模块化设计,开发人员可以选择内建模块,也可以自行创建,从而以更快的速度和比开发人员当前更强有力的方式创建应用程序。获取DevExpress新版正式版下载DevExpress技术交流群10:532598169      欢迎一起进群讨论项目背景Min......