本文技术难度★★★,如果前编内容顺利执行,请继续。

如果Selenium尚无法灵活运用的读者,本文可能难度较大。

“理论联系实惠,密切联系领导,表扬和自我表扬”——我就是老司机,曾经写文章教各位怎么打拼职场的老司机。不记得没关系,只需要知道:有这么一位老司机,

穿上西装带大家打拼职场!

操起键盘带大家打磨技术!

上一篇IT老司机带着各位已经成功安装了Cypress,并且让Cypress成功运行起来了。上篇任意门☛(后Selenium时代,网页自动化测试用Cypress)

本篇,IT老司机教你写第一个Cypress测试用例。

·  正  ·  文  ·  来·  啦·

首先,回忆一下,怎么运行cypress?用npm命令安装cpress。新建一个web工程的目录,执行npx cypress open,然后稍等一会儿。命令成功返回,则当前目录出现一个cypress目录。同时,一个对话框出现,cypress执行界面出来了。

 

点开“examples”前面的三角图标,里面是示例test cases.

点击里面的具体js文件,就开始执行测试用例了。

当然,可以点右上角的“Run all specs”,执行全部用例。

Cypress界面出来了,就别关了。

起码在读者阅读完本文前,都不要关!

然后,我们可以学习今天的内容了。先写一个最近简单的test case。

在 cypressintegration 目录中新建一个js文件,比如:sample.spec.js。记得最左边的随便起名字,英文字母开头,英文数字混搭都可以。最后一定是 .spec.js 结尾。

刚开始的时候,一定不要思维扩散太大,先一步一步来!这是学IT的血的教训!

IT老司机用的WebStorm。用其他IDE工具也没问题的。

 

启动cypress,可以看到多了一行,就是我们刚创建的文件 sample.spec.js。

点一下,然后显示一堆错误… 我就不贴图了… 读者自己试验一下哈。

这是意料之中的!

什么内容都没有,不失败才是这个框架出bug了!

接下来,写点儿内容进去,先写个最简单的

describe('My First Test', function() {

it('Hello World!', function() {

expect(true).to.equal(true)

})

})

JS的程序,看起来跟JAVA、Python、C#神马的都不太一样。习惯就好了。

其实,再怎么不懂JS,看到“ expect(true).to.equal(true)”也能明白是断言了吧?

测试用例主体怎么写,待会儿再说,容我卖个关子。

这时候,在cypress界面里,点击sample.spec.js。出来测试结果,看起来这样的:

 

执行成功!

同样的,浏览器不要关闭。

实施在刚才的js文件里,把”equal(true)” 改成 “equal(faulse)”。浏览器里的测试结果马上变false。

重要知识点:cypress是实时执行test case的

最后,我们来一步一步写一个真实的测试用例。

1. 修改刚才写的测试用例,当然也可以新建一个.spec.js文件。内容如下:

describe('A real test case', function() {

it('Visits the webpage', function() {

cy.visit('https://example.cypress.io')

})

})

如果之前浏览器没关闭且您是修改原有文件的,那么test case自动被发现,自动执行。

浏览器别管哈~ 后面会体会到妙处!

 

2. 修改刚才的测试用例

加点儿查询DOM元素的功能。

修改后的代码看起来这样的:

describe('A real test case', function() {

it('Visits the webpage', function() {

cy.visit('https://example.cypress.io')

cy.contains('type')

})

})

浏览器没关的话,test case又自动执行了。

 

“type”在哪里?点击第二行的“CONTAINS type”,右侧网页内容自动定位到type链接。

读者自行试验一下,IT老司机就不截图了。

3. 因为刚才找到的“type”是个超链接,当然就可以点击了。下面来演示一下点击操作。

还是刚才代码基础上,修改成下面这个样子:

describe('My First Test', function() {

it('clicks the link "type"', function() {

cy.visit('https://example.cypress.io')

cy.contains('type').click()

})

})

其实就是后面加了个click()方法。

浏览器里的测试用例自动又更新了。

 

相当于点击了type链接后,自动跳转了。

4. 加断言,判断测试是否正确。

点击“type”链接后,跳转的网页链接(https://example.cypress.io/commands/actions )应该包含“/commands/actions”。那么,断言可以设置成新链接地址中是否包含那一串字符。

继续修改刚才的代码,变成下面这个样子:

describe('My First Test', function() {

it('clicking "type" navigates to a new url', function() {

cy.visit('https://example.cypress.io')

cy.contains('type').click()

cy.url().should('include', '/commands/actions')

})

})

浏览器自动刷新,test case自动执行。结果如下图:

 

到此,第一个有意义的Web自动化测试用例完成了。有DOM元素查找,有点击事件,有跳转,有断言。

麻雀虽小,但是五脏俱全,对不对?

看到最后一步完成时候,右下角的灰色框里面的“Email address”了吗?文本框,可以填写内容,可以提交,对不对?

刚才操作都是一路顺利,没有degug过程,太顺利了,对不对?

预知怎么操作文本框,怎么debug,且听下回分解!

各位读者,您们的阅读量是我的动力!

如果您觉得本文还可以一读,请不吝转发!IT老司机继续带各位一起探究Cypress!

谢谢!!

作  者:Testfan Arthur

出  处:微信公众号:自动化软件测试平台

版权说明:欢迎转载,但必须注明出处,并在文章页面明显位置给出文章链接

Cypress自动化测试系列之二的更多相关文章

  1. Cypress自动化测试系列之三

    本文技术难度★★★,如果前编内容顺利执行,请继续. 如果Selenium尚无法灵活运用的读者,本文可能难度较大. “理论联系实惠,密切联系领导,表扬和自我表扬”——我就是老司机,曾经写文章教各位怎么打 ...

  2. 自动化测试系列(二)|API测试

    在上次的自动化测试系列(一)中为大家大体介绍了自动化测试的概念,本文主要针对API测试的概念及API测试在猪齿鱼Choerodon中的实践展开. API(应用程序编程接口)测试是一种软件测试,可以直接 ...

  3. (转载)python2+selenium自动化测试系列(二)

    16.Selenium2+python自动化16-alert\confirm\prompt 17.Selenium2+python自动化17-JS处理滚动条 18.Selenium2+python自动 ...

  4. Selenium3 + Python3自动化测试系列十二——窗口截图与关闭浏览器

    窗口截图 自动化用例是由程序去执行的,因此有时候打印的错误信息并不十分明确.如果在脚本执行出错的时候能对当前窗口截图保存,那么通过图片就可以非常直观地看出出错的原因.WebDriver提供了截图函数g ...

  5. 自动化测试系列(三)|UI测试

    UI 测试是一种测试类型,也称为用户界面测试,通过该测试,我们检查应用程序的界面是否工作正常或是否存在任何妨碍用户行为且不符合书面规格的 BUG.了解用户将如何在用户和网站之间进行交互以执行 UI 测 ...

  6. RF+Appium框架自动化测试系列一之(Mac下Appium环境搭建)万事开头难

    消失了3个月,有一段时间没来园子更新博客了,各位看官见谅哈哈,消失是因为刚换了工作环境没外网,好多笔记没能及时的记录分享,以后有时间慢慢补上吧,这段时间主要接触了移动端app的自动化测试,公司为了快速 ...

  7. .net基础学java系列(二)IDE 之 插件

    上一篇文章.net基础学java系列(二)IDE "扎实的基础"+"宽广的视野",基本可以帮我们摆脱码畜.码奴.码农的命运! IT领袖:IT大哥:IT精英:IT ...

  8. 【疯狂造轮子-iOS】JSON转Model系列之二

    [疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...

  9. 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新

    上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...

随机推荐

  1. 阶段3 3.SpringMVC·_02.参数绑定及自定义类型转换_3 配置解决中文乱码的过滤器

    输入中文 中文后台接收到 全部乱码 springMvc提供了过滤器 配置过滤器 characterEncodingFilter是首字母小写当做起的名称.当然这里也可以任意起名字.为了对应所以修改类名首 ...

  2. Rxjava2实战--第四章 Rxjava的线程操作

    Rxjava2实战--第四章 Rxjava的线程操作 1 调度器(Scheduler)种类 1.1 RxJava线程介绍 默认情况下, 1.2 Scheduler Sheduler 作用 single ...

  3. C#反射动态创建实例并调用方法

    在.Net 中,程序集(Assembly)中保存了元数据(MetaData)信息,因此就可以通过分析元数据来获取程序集中的内容,比如类,方法,属性等,这大大方便了在运行时去动态创建实例. MSDN解释 ...

  4. go语言20小时从入门到精通(六、工程管理)

    在实际的开发工作中,直接调用编译器进行编译和链接的场景是少而又少,因为在工程中不会简单到只有一个源代码文件,且源文件之间会有相互的依赖关系.如果这样一个文件一个文件逐步编译,那不亚于一场灾难. Go语 ...

  5. HTTP 请求中的 Form Data 与 Request Payload 的区别

    HTTP 请求中的 Form Data 与 Request Payload 的区别 前端开发中经常会用到 AJAX 发送异步请求,对于 POST 类型的请求会附带请求数据.而常用的两种传参方式为:Fo ...

  6. Spring体系

    1.Spring简介 Spring是一个轻量级Java开发框架,最早有Rod Johnson创建,目的是为了解决企业级应用开发的业务逻辑层和其他各层的耦合问题.它是一个分层的JavaSE/JavaEE ...

  7. [转帖]全方位掌握OpenStack技术知识

    全方位掌握OpenStack技术知识 http://www.itpub.net/2019/06/17/2206/ 架构师技术联盟的文章 相当好呢. 大家好,我是小枣君.最近几年,OpenStack这个 ...

  8. Linux的桌面环境gnome、kde、xfce、lxde 等等使用比较

    如果不是加入了图形界面,微软的Windows系列操作系统不会成功地占领计算机桌面这块高地.这种人机交换的图形化界面,使得界面更加直观.简易.而且更人性化,同时也大大减少了使用者的认知负担,普通用户无需 ...

  9. Oacle常用语句

    1.建表语句 ) NOT NULL, region_id ) NOT NULL, salesperson_id ) NOT NULL, ) NOT NULL, ) NOT NULL, tot_orde ...

  10. HDU 3416 Marriage Match IV (最短路建图+最大流)

    (点击此处查看原题) 题目分析 题意:给出一个有n个结点,m条单向边的有向图,问从源点s到汇点t的不重合的最短路有多少条,所谓不重复,意思是任意两条最短路径都不共用一条边,而且任意两点之间的边只会用一 ...