端到端测试框架Cypress简介

2024-04-09 10:38

本文主要是介绍端到端测试框架Cypress简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

初识Cypress

Cypress (https://www.cypress.io/)是一款功能强大的端到端的Web 测试框架。相比于其他类似最大的特点就是有个可视化的UI界面,调试起来相当直观方便。使用的时候要按业务需要写一些测试用例就可以用带界面或者纯命令行模式来跑了。

安装

Cypress依赖于node js 环境,估计做web 开发的人都是有的。Cypress本身可以用npm安装在目标项目下:

npm install cypress --save-dev

或者用yarn 也行

yarn add cypress --dev

官网上还有个官方的  cypress/base Docker容器可供使用。

初次使用的话Cypress 还很贴心地为我们创建了示例项目:

使用

Cypress有两种运行模式:open和run。其中open是有图形用户界面的,适合开发调试时使用。而run是命令行模式,更适合跑自动化测试,比如在jenkins的pipeline上。启动方式如下:

npm run cypress:open
npm run cypress:runyarn run cypress open
yarn run cypress run

Cypress 的图形界面有两个窗口,首先出现的是主窗口:

这个界面会列出当前项目里面所有的测试文件(以.spec.js结尾的)。用户可以点击某个文件来跑这个测试或者点击右上角的链接跑所有的测试。然后就会打开一个独立的浏览器作为测试页面的容器。如下图:

在图中我们可以看到在浏览器中也不单单是被测试网页,而是有一个网页框架包围着它的。左边的区域就是所有的测试用例还有每个测试的步骤和状态的记录。右边的iframe才是要测试的目标网页。

点开某个测试过的case,我们可以看到before each阶段是访问了指定网址。然后在test body里面每一步都干了什么,包括UI操作如点击,滚动之类,还有http请求了什么。还会有assert 的内容和结果,如果出错还有出错信息。

点击某一步的话还会显示当时的截图,真的是非常方便。

调试

使用Cypress图形界面的好处不只是可以看到页面上发生了什么,而且可以实时调试,方法和普通的网页调试基本没差别,而且不仅业务代码可以调试,而且测试代码也能调试。

此外,Cypress还提供了名为debug和debugger的API,用于在运行时暂停,这样用户就可以从容打开调试工具并且在console上做交互式调试了。

编写测试

目录结构

其实刚刚在自动初始化的时候,Cypress 已经给我们建好了测试目录就在项目根目录下的./cypress下面:

不仅如此还初始化了基本的测试框架代码而且插入了一些例子在./cpyress/integration/examples目录下,将来可以删除这些例子。

我们可以在integration文件夹下建立子文件夹和新的测试文件。

在cypress/support/commands.js里加入自定义API。

测试代码

Cypress 测试的写法也很符合我们的习惯:

  • 用describe 来声明一个测试用例组
  • 用it 来写一个测试用例
  • 用expect来做断言
  • 还有我们写测试常用的beforeAll, beforeEach, afterAll, afterEach之类的API
  • 可以使用cy.xxx方法来调用cypress 特有的API或是我们在commands.js里面自定义的API,比如cy.visit(url)是跳转到指定的URL

更多细节请参考cypress API文档:https://docs.cypress.io/api/api/table-of-contents.html

移动设备适配

现在的web 前端开发往往要同时支持桌面和移动端,甚至就是以移动端为主。所以能够模拟并测试不同的屏幕尺寸就显得十分必要了。因此cypress 提供了viewport 方法来解决这个问题,cypress内置了很多不同设备屏幕尺寸比如ipad-2, iphone-x也可以自定义屏幕分辨率大小。

测试组件

Cypress 也可以用于测试Vue或React组件,但需要安装特定的库: @cypress/vue 或者@cypress/react 。它的做法是提供一个mount API把组件加载渲染出来进行测试,而不是真正的全部网页。

这篇关于端到端测试框架Cypress简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/887932

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte