Cypress安装与使用教程(1)—— 软测大玩家

news2024/12/26 0:18:35

在这里插入图片描述

 
 

在这里插入图片描述
😏作者简介:博主是一位测试管理者,同时也是一名对外企业兼职讲师。
📡主页地址:【Austin_zhai】
🙆目的与景愿:旨在于能帮助更多的测试行业人员提升软硬技能,分享行业相关最新信息。
💎声明:博主日常工作较为繁忙,文章会不定期更新,各类行业或职场问题欢迎大家私信,有空必回。

在这里插入图片描述

 
 

阅读目录

  • 1. 软件介绍
  • 2. 软件安装
  • 3. 软件使用
  • 4. 后话

1. 软件介绍

在这里插入图片描述
  前一阵子有个行业里做WMS业务的朋友推荐给我一款软件,说做web端的测试特别棒,名字叫Cypress,这几天也是抽空看了下,发现还真的挺有意思的。今天就结合这款软件的一些基础用法和个人见解来给大家讲一讲这款Cypress。

  其实准确来说Cypress是一款测试框架,其擅长针对端到端的web端测试,在博主结合自己团队的测试业务过程中,发现其在自动化测试与兼容性测试的各类测试场景中有着比较良好的表现。比如我们在进行自动化测试用例代码的修改过程中就可以使用Cypress的热重载特性来实现实时的reloading与debug,相较于每次修改代码后都需要重新启动的一些自动化测试工具,这个的维护与调试效率要来的高得多。其他优势就不在这里展开太多了,接下来我们就先来看看软件的安装与基础使用吧。

 
 

2. 软件安装

在这里插入图片描述
  Cypress因为可以跨平台,所以它的安装方法也是较为的丰富,这里我们就暂时以Windows平台来进行介绍。

  我们先来到官网【Cypress官网】,在首页点击右上角的Install。这里要提示一下,Cypress网站与软件的用户登录是需要用到魔法的,不开可能会访问不到。

在这里插入图片描述
 
 

  在接下来弹出的选项窗口中选择右侧的Direct Download,直接下载程序的压缩包。
在这里插入图片描述

 
 

  下载完成后直接解压到你指定的路径即可,接下来我们直接在解压对应的Cypress文件夹内启动执行文件。进入软件后如下图:
在这里插入图片描述

 
 

3. 软件使用

在这里插入图片描述

  点击Continue后我们就可以直接开始使用了,但这里还是推荐大家先进行下登录,不仅可以使用Cypress Could还可以保存测试项目的设置与查看测试结果。主流的账号,比如Google、GitHub都是可以快速绑定登录的。登录完成后我们可以看到主界面非常的简单,只有一个选项。这里大家可以将自己的web被测对象的项目文件夹(没有?那就手动创建或去公司的代码仓库里去拉取)手动拖进下面的提示区内,或者直接左键选择你的web测试项目文件夹。注意:这里不是让你把项目代码文件放进去,而是测试团队将要使用的Cypress的项目文件夹。
在这里插入图片描述

 
 

  添加完成后,我们就可以在首页界面看到两个选项,这里我们选择第一个端到端测试(END to END),说到端对端测试,它其实就是模拟了最终用户的实际使用情况,关注的是整个应用程序的各个部分之间的集成和互动。旁边的组件测试因为没有NPM的依赖所以没办法使用,这个无视就行了。
在这里插入图片描述

 
 

  接下来我们选择被测对象所运行的浏览器环境,这个只需根据自己的测试任务来对应选择即可,没有什么讲究。
在这里插入图片描述

 
 

  在我们选择了对应的浏览器之后Cypress就会打开这样的一个测试项目主页,然后创建一个空的规范文件来进行接下去的端到端测试。
在这里插入图片描述

 
 

  在弹出的文件命名对话框中输入你指定的文件名即可。
在这里插入图片描述

 
 

  创建文件完成后直接会跳出成功添加的对话框,这里我们无需去运行这个规范文件,直接点击右上角的大叉,关闭窗口即可。
在这里插入图片描述

 
 

  关闭后会返回至首页,这里我们可以看到之前创建的规范文件,规范文件以列表形式展现,这里需要注意的是之后只要在文件内进行任何修改,Cypress都会进行记录并显示修改内容。
在这里插入图片描述

 
 

  点击进入刚才的规范文件,我们可以看到左侧的文件内已经有了一个用例的执行结果并显示passes,这个不用去关注,默认的规范文件中本来就只有一条访问cypress样例网站的用例,毕竟会成功。这里我们需要将测试代码修改为我们自己的业务测试代码。我们将鼠标悬停在左侧的TEST BODY字样上,这时右侧会显示Open in IDE的选项,我们可以选择自己平时常用的一款IDE打开进行代码的编辑。

在这里插入图片描述
 
 

  这里博主用的IDE是PyCharm,下图就是样例中的代码,可以看出逻辑十分的简单,就是运行测试用例并访问example.cypress.io。我们需要在这里将自己的测试业务代码编辑进去。
在这里插入图片描述
 

  这里我们就将测试逻辑修改为自己的业务,为了方便演示,我们就将逻辑变更为判断访问的网址是否为我们指定的网址,对就测试通过,错就测试失败。

describe("test_url_check", function () {
  it("visit_url_check", function () {
    cy.visit("www.rubies-test.com"); 
    cy.url().then((url) => {
      if (url === "https://www.rubies-test.com") {
        cy.log("Test results correct");
      } else {
        cy.log("Test result error");
      }
    });
  });
});

 

  这里修改完代码保存之后就会直接触发用例执行,并且在之前的规范文件列表画面中显示代码的更新时间。
在这里插入图片描述

 

  运行完之后我们就可以在当前页面查看用例的执行情况。可以看到下图我们的测试结果是成功的,并且正确打印出了测试结果。那么接下来我们做一点点小小的改动,我们将网址变化一下,使得断言的结果与实际结果不同,来看看会发生什么。
在这里插入图片描述
 

  我们将代码添加断言操作,并将访问的网站改成C站,光从代码查看就能得知这个断言一定不会成功,接下来我们看下执行后的结果会是什么样的。

describe("test_url_check", function () {
  it("visit_url_check", function () {
    cy.visit("https://austin.blog.csdn.net/");
    cy.url().should("eq", "https://www.baidu.com/");
  });
});

 

  从下图就可以看到断言这块的逻辑报错了,其实就是两个url结果不相等导致的代码错误。这边要注意一下,用例执行失败的业务操作可以根据各自的习惯来进行定义,因为它本身没有用例执行失败的状态,所以我们可以去在这一块业务进行下完善与优化。
在这里插入图片描述

 
 

4. 后话

在这里插入图片描述
  可以看到Cypress的安装与基础使用是属于比较简单直白的类型的,只不过因为它是主要用于web代码调试与端对端测试的场景,前端开发人员自不用多说,而对于测试人员则必须掌握一定的Javascript的代码基础才能够灵活使用本软件。后续也会基于不同的场景来介绍更多的组合与进阶功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1024571.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

半导体划片机工艺应用

半导体划片工艺是半导体制造过程中的重要步骤之一,主要用于将大尺寸的晶圆切割成小片,以便进行后续的制造和封装过程。以下是一些半导体划片工艺的应用: 晶圆划片:在半导体制造过程中,需要将大尺寸的晶圆切割成小片&am…

【数据库系统概论】数据库系统外部的体系结构

单用户结构主从式结构分布式结构客户机/服务器结构(C/S结构)浏览器 / 服务器结构(B/S结构)感谢 💖 上一篇文章 数据库系统的三级模式和二级映射介绍的是数据库系统内部的体系结构,是从应用开发…

计算机网络知识补充(1)

计算机网络:是一个将分散的,具有独立功能的计算机系统,通过通信设备和线路进行连接起来,由功能完善的软件实现资源共享和信息共享的系统,计算机网络是互连的,自治的计算机集合 互连:通过通信链路来进行互联互通 自治:没…

云安全威胁和责任

云计算的共享特性和按需定制本质除了给企业带来效率上提升,也引入了新的安全威胁,有可能使企业得不偿失。 之前云安全联盟(CSA)的报告便指出,云服务天生就能使用户绕过公司范围内的安全策略,建立起自己的影子IT项目服务账户。 新的…

全面感知,智能预警!燃气感知云,守护城市“烟火气”

燃气安全如何保障?燃气企业如何精准运营?天翼物联基于感知云平台创新能力,提供燃气感知云服务,包括泛协议接入、感知云燃气平台、燃气感知数据治理、决策处置大屏四大服务,构建燃气行业感知神经系统新型数字化底座&…

Interceptor的使用场景:拦截请求中的租户信息,注入到租户上下文中

业务场景 在SaaS环境中,租户是最重要的隔离业务数据的属性了,在自己的项目体系环境中,租户id能保证有值。但有个特殊场景,某些特殊权限的账号需要修改指定租户的内容,也即前端会携带租户信息过来,并且内部涉…

【力扣-每日一题】2560. 打家劫舍 IV

class Solution { public:bool check(vector<int> &nums,int max_num,int k){//只需要计算可以偷的房间。在满足最大值为max_num下时&#xff0c;能偷的最多的房间&#xff0c;与k值比较//如果大于K&#xff0c;说明max_num还可以缩小//如果小于看&#xff0c;说明ma…

深入解析容器与虚拟化:技术、对比与生态

深入解析容器与虚拟化&#xff1a;技术、对比与生态 文章目录 深入解析容器与虚拟化&#xff1a;技术、对比与生态容器和虚拟化的基本概念和原理容器的定义和特点虚拟化的定义和特点 容器使用场景容器和虚拟机的对比虚拟化技术的四个特点容器实现虚拟化的原理常见容器引擎和容器…

【Ubuntu配置ssh和sftp与windows的xshell连接】

【Ubuntu配置ssh和sftp与windows的xshell连接】 一、Ubuntu配置ssh1、查看是否已经安装2、安装openssh server3、修改端口 修改Port后的参数4、重启ssh5、查看状态6、查看端口 二、windows连接 一、Ubuntu配置ssh 1、查看是否已经安装 dpkg -l | grep ssh2、安装openssh serv…

IntelliJ IDEA学习总结(3)—— IntelliJ IDEA 常用快捷键(带动图演示)

一、构建/编译 Ctrl + F9:构建项目 该快捷键,等同于菜单【Build】—>【Build Project】 执行该命令后,IntelliJ IDEA 会编译项目中所有类,并将编译结果输出到out目录中。IntelliJ IDEA 支持增量构建,会在上次构建的基础上,仅编译修改的类。 Ctrl + Shift + F9:重新编…

程序员戴什么样的眼睛比较好

眼镜https://baijiahao.baidu.com/s?id1770288495355869186&wfrspider&forpc

【JDK 8-集合框架】5.3 limit 和 sorted 函数

一、sorted 函数 二、limit 函数 三、实战 执行结果&#xff1a; 一、sorted 函数 对流进行自然排序&#xff0c;其中的元素必须实现Comparable 接口 sorted(Comparator<? super T>comparator) 用来自定义升降序 二、limit 函数 获取指定数量的元素 (limit(long …

《机器学习基石前四章复习》

【引言】 训练样本D和最终测试h的样本都是来自同一个数据分布&#xff0c;这是机器能够 学习的前提。另外&#xff0c;训练样本D应该足够大&#xff0c;且hypothesis set的个数是有限的&#xff0c;这样 根据霍夫丁不等式&#xff0c;才不会出现Bad Data&#xff0c;保证Ein≈…

2023年9月19日

2> 完成文本编辑器的保存工作 头文件 #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QFontDialog> #include <QMainWindow> #include <QFont> #include <QMessageBox> #include <QDebug> #include <QColorDialog> #include &l…

Flask框架-1-[群聊]: flask-socketio实现websocket的功能

一、项目结构 flask_websocket |---static |---js |---jquery-3.7.0.min.js |---socket.io_4.3.1.js |---templates |---home |---group_chat.html |---index.html |---app.py 1.1、python环境 python3.9.0 1.2、依赖包 Flask2.1.0 eventlet0.33.3 Flask-SocketIO5.3.4 1.…

温习JAVA

1.时间 作业题&#xff1a; 1.子串在字符串中出现的次数 import java.util.Scanner;/*** 分别在控制台输⼊字符串和⼦字符* 串&#xff0c;并计算字符串中⼦字符串出现的* 次数。indexOf(subs,n)*/ public class H5 {public static void main(String[] args) {Scanner scnew …

linux搭建单机ES,集成ik分词器,文本抽取,Kibana可视化平台

Elasticsearch单机&#xff08;Linux&#xff09; 准备工作 第一项&#xff1a; 创建运行Elasticsearch和Kibana专用的普通用户&#xff0c;因为 elasticsearch 和 kibana 不允许使用 root用户启动&#xff0c;所以需要创建新用户启动。 linux用root权限创建一个用户赋权即可…

BootStrap中的布局

1.BootStrap中的布局 2.BootStrap 中的媒体查询 // Extra small devices (portrait phones, less than 576px) media (max-width: 575px) { ... }// Small devices (landscape phones, 576px and up) media (min-width: 576px) and (max-width: 767px) { ... }// Medium dev…

38 | 统一测试数据平台

测试数据准备的 2.0 时代 在Java中可以利用Builder Pattern&#xff0c;创建数据时如对其中的某个或某几个参数有特定要求的话&#xff0c;可以通过“.withParameter()”的方式指定&#xff0c;而没有指定的参数将自动采用默认值。 UserBuilder.withCountry(“US”).withBuild…

深度学习-ONNX模型

ONNX&#xff08;Open Neural Network Exchange&#xff09;是一种开放的、跨平台的模型交换格式&#xff0c;旨在帮助机器学习开发人员轻松地在不同的深度学习框架之间共享模型。 ONNX是由Microsoft和Facebook合作推出的&#xff0c;它使得不同深度学习框架之间可以相互转换模…