百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

前端自动化测试框架(前端自动化测试框架cypress电子书)

ccwgpt 2024-09-17 12:46 26 浏览 0 评论

一、应用而生的前端测试框架

随着前端页面开发演化成了前端应用程序开发后,前端实际具备了后端的一切能力(Node.js作为前端Server,也可以提供接口接收客户端的请求并处理,能够保存、处理后端传递过来的数据),但Selenium/WebDriver本身却只能单纯的用在UI测试层面(除非加入第三方库),其越来越不能满足整个测试行业对前端自动化框架的需求。

越来越多的前端测试框架涌现,如Karma、Nightwatch、Protractor、TestCafe、Cypress和Puppeteer,这些测试工具出中有的还依托于selenium/webdriver的功能或填补了其空白,其中佼佼者如Cypress,它的底层完全不依托Selenium/webdriver,运行速度也比其快。

Cypress和被测应用程序运行在同一个浏览器界面,使得Cypress可以测试金字塔的任意层,且Cypress是不需要任何第三方扩展就具备一个优秀的测试框架的全部特征事实。


二、前端自动化测试框架组成

1.什么是测试框架?

是由一个或多个自动化测试基础模块、自动化测试管理模块、自动化测试统计模块等组成的工具集合。

2.一个优秀的前端自动化框架组成部分?

底层核心驱动库:一般指用于操作被测应用程序的第三方库

可重用的组件:一般用于降低开发成本,如时间处理模块、登录模块等。

对象库:存储被测对象的仓库。实际应用中常常将页面进行分组,把一个页面上的所有对象放到一个类里,也就是PO模式(Page Object)

配置文件:测试环境的配置、应用程序的配置。

工具:能完成特定功能的独立程序或代码片段

方便易用的测试数据:数据在测试中的重要性不言而喻,数据创建分为实时创建和事先创建。

3.如何创建数据?

人工构造数据

通过调用前端GUI或后端API构造数据

直接向DB里面插入所需数据

4.测试用例的组织和运行

测试用例在测试框架中体现是测试脚本,测试脚本应该做到业务操作粒度合适,断言明确充分,前后脚本解耦

5.测试框架需要能支持什么?

测试用例顺序或者并发执行

测试用例分组运行

动态挑选测试用例执行

根据测试数据自动生成测试用例

6.什么错误恢复机制?

由于环境、程序、代码存在各种不确定因素,测试框架需要具备一定的错误恢复机制。

测试用例执行中引起的错误类型一般分为:代码/运行导致的错误、环境/依赖导致的错误

错误处理措施:停止运行和错误恢复。错误恢复通常标记当前用例识别,清理失败数据,恢复测试环境,然后运行下一条测试。错误恢复时机可以为事先恢复(当前用例运行前将环境和数据恢复到初始状态)和事后恢复(当前用例运行完成后将环境和数据恢复到初始状态)

7.全面的测试报告

测试用例条数统计、测试用例成功/失败百分比,测试用例总执行时间等总体信息。

单条测试用例包括测试用例ID、测试用例运行结果、测试用例运行时间、测试用例所属模块、测试失败时刻系统截图、测试的日志等信息;

测试报告应该包括不同格式如HTML、XML(用于跟CI集成)等;

包含完善的日志文件,方便出错时排查和定位。


三、前端自动化测试框架设计原则

1.代码和数据分离

2.剥离可共用的库

3.可移植性,可维护性

4.高扩展性,高稳定性

5.版本控制

相关推荐

MFC、Qt、WPF?该用哪个?(mfc和wpf区别)

MFC、Qt和WPF都是流行的框架和工具,用于开发图形用户界面(GUI)应用程序。选择哪个框架取决于你的具体需求和偏好。MFC(MicrosoftFoundationClass)是微软提供的框架,...

一款WPF开发的通讯调试神器(支持Modbus RTU、MQTT调试)

我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!项目介绍Wu.CommTool是一个基于C#、WPF、Prism、MaterialDesign...

关于面试资深C#、WPF开发工程师的面试流程和问题

一、开场(2-3分钟)1.欢迎应聘者,简单介绍公司和面试流程。2.询问应聘者是否对公司或岗位有初步的问题。二、项目经验与技术应用(10-20分钟)1.让应聘者详细介绍几个他参与过的C#、...

C# WPF MVVM模式Prism框架下事件发布与订阅

01—前言处理同模块不同窗体之间的通信和不同模块之间不同窗体的通信,Prism提供了一种事件机制,可以在应用程序中低耦合的模块之间进行通信,该机制基于事件聚合器服务,允许发布者和订阅者之间通过事件进行...

WPF 机械类组件动画制作流程简述(wps上怎么画机械结构简图)

WPF机械类组件动画制作流程简述独立观察员2025年3月4日一、创建组件创建组件用户控件,将组件的各部分“零件”(图片)拼装在一起,形成组件的默认状态:二、给运动部分加上Rend...

C#上位机WinForm和WPF选哪个?工控老油条的"血泪史"

作为一个从互联网卷进工控坑的"跨界难民",在这会摸鱼的时间咱就扯一下上位机开发选框架这档子破事。当年我抱着WPF的酷炫动画一头扎进车间,结果被产线老师傅一句"你这花里胡哨的玩意...

【一文扫盲】WPF、Winform、Electron有什么区别?

近年来,随着软件开发的不断发展,开发人员面临着选择适合他们项目的各种框架和工具的挑战。在桌面应用程序开发领域,WPF、Winform和Electron是三个备受关注的技术。本文将介绍这三者的区别,帮助...

一个开源、免费、强大且美观的WPF控件库

我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!项目介绍HandyControl是一套基于WPF(WindowsPresentationF...

WPF 根据系统主题自动切换浅色与深色模式

WPF根据系统主题自动切换浅色与深色模式控件名:Resources作者:WPFDevelopersOrg-驚鏵原文链接[1]:https://github.com/WPFDevelopers...

WPF与WinForm的本质区别(wpf与maui)

在Windows应用程序开发中,WinForm和WPF是两种主要的技术框架。它们各自有不同的设计理念、渲染机制和开发模式。本文将详细探讨WPF与WinForm的本质区别,并通过示例进行说明。渲染机制W...

Win10/Win11效率神器再进化:微软发布PowerToys 0.90.0版本

IT之家4月1日消息,微软今天(4月1日)更新PowerToys,在最新发布的0.90.0版本中,修复多个BUG之外,引入多项功能更新,为Windows10、Windows...

一款非常漂亮的WPF管理系统(wpf架构及特性)

我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!WPFManager项目介绍该项目是一款WPF开发的管理系统,数据库采用的MSSqlserv...

WPF 实现描点导航(wpf按钮的点击事件)

WPF实现描点导航控件名:NavScrollPanel作者:WPFDevelopersOrg-驚鏵原文链接[1]:https://github.com/WPFDevelopersOrg/WPF...

微软更新基于Win11的Validation OS 2504:增强 .NET与WPF

IT之家5月1日消息,科技媒体NeoWin今天(5月1日)发布博文,报道称微软公司更新基于Windows11的ValidationOS,增强支持.NET和WPF,并优...

WPF的技术架构与优势(wpf的前景)

WindowsPresentationFoundation(WPF)是一个现代化的用户界面框架,专为构建Windows应用程序而设计。它通过分层的技术架构和丰富的功能集,提供了全面的应用程...

取消回复欢迎 发表评论: