Ecom 赛普拉斯测试
使用 Cypress 进行 E2E 测试教您如何使用 Cypress 执行端到端 (E2E) 测试是 JavaScript 中最流行的自动化测试工具之一,特别是对于 Web 应用程序。我将详细解释所有概念和步骤。
什么是端到端测试?
端到端测试 (E2E) 是自动化测试,用于验证应用程序从开始到结束的完整行为,模拟用户与界面的交互。这些测试很重要,因为它们验证应用程序的所有部分在真实环境中是否按预期正常工作。
赛普拉斯:它是什么以及它如何工作?
Cypress 是一个用于 Web 应用程序自动化测试的工具。它被设计为易于使用、功能强大且快速。它允许您编写与应用程序的用户界面交互的测试,就像用户一样,单击按钮、填写表单、验证文本等等。
Cypress 的一些重要特性:
- 实时测试:它在浏览器本身中运行测试,允许您实时查看正在运行的测试。
- 易于设置:无需复杂的设置即可开始。
- 快速执行:由于Cypress在浏览器中运行,因此与其他E2E测试工具相比,测试执行速度更快。
- CI/CD 集成:它可以轻松与 CI/CD 管道集成以实现测试自动化。
模块 34 演练
1.概念化 Cypress 工具
Cypress是一款Web应用的自动化测试工具,主要用于E2E测试。它旨在直接与浏览器中的应用程序代码交互,使测试更加高效。
2.在机器上安装 Cypress
要开始使用 Cypress,您需要将其安装到您的项目中。这是安装命令:
npm install cypress --save-dev
这会将 Cypress 安装为项目中的开发依赖项。
3.启动赛普拉斯
安装Cypress后,您可以在终端中使用以下命令打开它:
npm install cypress --save-dev
这将打开 Cypress Test Runner,您可以在其中看到浏览器中运行的测试。它还会在您的项目中创建一个 cypress 文件夹,其中存储所有测试和配置。
4.使用描述函数对测试进行分组
在 Cypress(和 Jest)中,我们使用 describe 对属于同一套件或模块的多个测试进行分组。这有助于以更结构化的方式组织测试。
npx cypress open
在上面的例子中:
- describe 用于对登录相关测试进行分组。
- 它定义了组内的特定测试。其内部接下来是执行验证的代码(测试步骤)。
5.使用 it 函数
it 函数用于定义各个测试用例。每个测试用例必须是独立的并代表应用程序的特定功能或行为。
6.使用 cy.get 函数检索元素
cy.get 函数用于选择要在测试中交互的页面元素。
示例:
describe('Teste de Login', () => { it('Deve realizar o login com sucesso', () => { cy.visit('https://exemplo.com/login'); cy.get('input[name="username"]').type('usuario'); cy.get('input[name="password"]').type('senha123'); cy.get('button[type="submit"]').click(); cy.url().should('include', '/dashboard'); }); });
这里,cy.get 搜索 name="username" 的输入和 type="submit" 的提交按钮,然后执行 type 和 点击。
7. VScode 和自动完成简介
您可以使用 VSCode 编辑测试并利用 Cypress 自动完成功能,这可以通过在您键入时建议方法和命令来轻松正确编写测试。
8.使用层次关系
Cypress 允许您使用更复杂的 CSS 选择器根据页面层次结构选择元素。例如,您可以选择具有特定类的 div 内的按钮:
cy.get('input[name="username"]').type('usuario'); cy.get('button[type="submit"]').click();
9.构建过滤测试
过滤测试的一个示例是检查应用过滤器时项目列表是否正确更新。 Cypress 允许您轻松执行此类测试,与过滤器交互并检查结果。
cy.get('.modal').find('button').click(); // Encontra o botão dentro de .modal e clica
10。使用 beforeEach 函数
beforeEach 函数对于在每次测试之前配置应用程序状态非常有用。当您需要在运行测试之前确保应用程序处于初始状态时,这一点尤其重要。
npm install cypress --save-dev
11。了解 Cypress 返回类型
Cypress 使用 Promise 来管理异步时间,但它会自动处理这些 Promise,从而使测试变得更简单。在许多情况下没有必要使用await或.then(),因为Cypress在内部处理这个问题。
12。组织代码以减少行数
保持测试的组织性和可重用性至关重要。您可以创建辅助函数并重用代码片段。
示例:
npx cypress open
13。了解 Cypress 的其他功能
- 截屏:Cypress 可以在测试过程中自动截屏。这可以帮助您直观地了解测试失败时发生的情况。
describe('Teste de Login', () => { it('Deve realizar o login com sucesso', () => { cy.visit('https://exemplo.com/login'); cy.get('input[name="username"]').type('usuario'); cy.get('input[name="password"]').type('senha123'); cy.get('button[type="submit"]').click(); cy.url().should('include', '/dashboard'); }); });
生成报告:Cypress 允许您生成测试执行报告,这使得分析结果变得更加容易。
Cypress Run:要在无头模式(没有图形界面)下运行测试,请使用以下命令:
cy.get('input[name="username"]').type('usuario'); cy.get('button[type="submit"]').click();
- HTTP 请求模拟:您可以使用 Cypress 模拟服务器响应,而无需进行实际调用。这对于使用特定数据测试场景非常有用。
cy.get('.modal').find('button').click(); // Encontra o botão dentro de .modal e clica
14。模拟 Service Worker (MSW) 安装
Mock Service Worker 是一个允许您在测试中拦截 HTTP 请求的工具。它可以与 Cypress 一起使用来模拟请求并控制响应。
cy.get('.filter').select('Option 1'); cy.get('.item-list').should('have.length', 5);
然后您可以配置网络处理程序来拦截请求。
结论
在第 34 单元中,您学习了如何使用 Cypress 对您的应用程序执行 E2E 测试,确保其在实际使用情况下正常工作。您学习了如何配置 Cypress、编写测试、与页面元素交互以及使用 beforeEach、cy.get、屏幕截图、报告等功能。这些测试对于确保您的应用程序正常工作并且不会引入新的错误至关重要。
以上是Ecom 赛普拉斯测试的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。
