”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Cucumber.js:行为驱动测试的完整指南

Cucumber.js:行为驱动测试的完整指南

发布于2024-11-09
浏览:509

Cucumber.js: A Complete Guide to Behavior-Driven Testing
Cucumber.js 是一种流行的工具,用于运行以简单语言编写的自动化测试,允许开发人员和非开发人员协作进行测试。它在行为驱动开发 (BDD) 中特别有用,因为利益相关者之间的清晰沟通是关键。通过使用人类可读的语言,Cucumber js 使产品所有者、测试人员和开发人员能够确保软件按预期运行,同时提高应用程序的整体质量。
了解行为驱动开发 (BDD)
Cucumber.js 围绕行为驱动开发 (BDD) 原则构建,这是一种鼓励技术和非技术利益相关者之间沟通的软件开发方法。在 BDD 中,测试是用共享语言编写的,以便所有团队成员都可以为理解需求做出贡献。通过关注行为而不是技术细节,BDD 确保每个人(从业务分析师到开发人员)对软件应如何运行都有相同的理解。
BDD 通常遵循“给定、何时、然后”的格式来描述场景:
• 给定:定义初始上下文(例如,“假设用户已登录”)。
• 何时:描述操作或事件(例如,“当用户单击提交按钮时”)。
• 然后:指定预期结果(例如,“然后提交表单”)。
Cucumber.js 使用此格式来启用自然语言测试。
安装和设置 Cucumber.js
要开始使用 Cucumber.js,您需要安装必要的 npm 包并配置您的项目。 Cucumber.js 作为 Node.js 包提供,您可以通过 npm 轻松安装它。以下是在 Node.js 项目中设置它的方法:

  1. 安装 Cucumber.js: 巴什 复制代码 npm install --save-dev @cucumber/cucumber
  2. 配置您的项目:为您的功能文件和步骤定义创建文件夹结构。例如: 珀尔 复制代码 ├── 特点 │ ├── 步骤_定义 │ └── my-feature.feature 安装后,您就可以编写第一个功能文件并创建相应的步骤定义。 编写您的第一个功能文件 Cucumber.js 的一个关键元素是功能文件,其中测试是使用 Gherkin 语法以简单的英语编写的。功能文件描述了从用户角度编写的场景中应用程序的行为。以下是测试登录功能的简单功能文件示例: 功能:登录功能

场景:使用有效凭据成功登录
假设用户位于登录页面
当用户输入有效凭据时
然后用户被重定向到仪表板
每个场景代表软件必须支持的特定用例。目标是以技术和非技术团队成员都能轻松理解的方式编写这些测试。
Cucumber.js 中的步骤定义
步骤定义是将特征文件中的自然语言步骤映射到可执行 JavaScript 代码的地方。每个步骤(例如,“假设用户位于登录页面”)对应于步骤定义文件中的一个方法。
以下是如何定义登录功能步骤的示例:
const { 给定、何时、然后 } = require('@cucumber/cucumber');

Given('用户位于登录页面', function () {
// 导航到登录页面的代码
});

When('用户输入有效凭据', function () {
// 输入有效用户名和密码的代码
});

Then('用户被重定向到仪表板', function () {
// 验证仪表板重定向的代码
});
Give、When 和 Then 函数来自 Cucumber.js 包,每个函数都将场景中的一个步骤映射到实现必要逻辑的 JavaScript 函数。
运行 Cucumber.js 测试
一旦您的功能文件和步骤定义准备就绪,您就可以运行 Cucumber.js 来执行测试并查看结果。在您的终端中,只需运行以下命令:
npx 黄瓜-js
Cucumber.js 将解析您的功能文件,将步骤与其相应的步骤定义进行匹配,并执行测试。输出将显示哪些场景通过或失败,让您清楚地了解应用程序的行为。
将 Cucumber.js 与其他测试工具集成
Cucumber.js 可以与 Mocha 或 Chai 等流行的测试框架集成,以增强测试套件的功能和结构。通过将 Cucumber.js 与这些框架相结合,您可以使用强大的断言库和测试功能来提高测试的深度。
例如,您可以在步骤定义中使用 Chai 进行断言:
const { 期望 } = require('chai');

Then('用户被重定向到仪表板', function () {
Expect(currentPage).to.equal('仪表板');
});
集成其他工具使您能够将 Cucumber.js 扩展到基本 BDD 场景之外,使其成为整体测试策略的灵活部分。
编写可维护的 BDD 测试的最佳实践
为了确保您的 Cucumber.js 测试保持可维护性和可扩展性,在编写测试时遵循某些最佳实践非常重要:

  1. 编写小型、独立的场景:每个场景都应该测试特定的行为,并且不应依赖于其他场景。这使您的测试更易于理解和维护。
  2. 避免过于复杂的步骤定义:步骤定义应保持重点和简洁。如果某个步骤需要太多逻辑,请考虑将其分解为更小的步骤或重构代码。
  3. 跨场景重用步骤:在可能的情况下,跨不同场景重用步骤定义,以减少重复并提高一致性。
  4. 保持功能文件易于理解:以开发人员和非技术团队成员都可以轻松理解的方式编写功能文件。清晰且描述性的场景可以改善整个团队的沟通。 结论 Cucumber.js 通过提供简单且易于理解的测试编写格式,提供了一种强大的方法来弥合开发人员、测试人员和利益相关者之间的差距。通过在 BDD 框架中使用 Cucumber.js,您可以确保您的测试与业务需求紧密结合,并且所有团队成员都对应用程序的行为方式有共同的理解。无论您是测试小型组件还是复杂的工作流程,Cucumber.js 都可以帮助您编写更清晰、更有效的测试,从而有助于您的软件项目的成功。
版本声明 本文转载于:https://dev.to/keploy/cucumberjs-a-complete-guide-to-behavior-driven-testing-12h1?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 查找当前执行JavaScript的脚本元素方法
    查找当前执行JavaScript的脚本元素方法
    如何引用当前执行脚本的脚本元素在某些方案中理解问题在某些方案中,开发人员可能需要将其他脚本动态加载其他脚本。但是,如果Head Element尚未完全渲染,则使用document.getElementsbytagname('head')[0] .appendChild(v)的常规方...
    编程 发布于2025-07-02
  • Java中假唤醒真的会发生吗?
    Java中假唤醒真的会发生吗?
    在Java中的浪费唤醒:真实性或神话?在Java同步中伪装唤醒的概念已经是讨论的主题。尽管存在这种行为的潜力,但问题仍然存在:它们实际上是在实践中发生的吗? Linux的唤醒机制根据Wikipedia关于伪造唤醒的文章,linux实现了pthread_cond_wait()功能的Linux实现,利用...
    编程 发布于2025-07-02
  • 在Python中如何创建动态变量?
    在Python中如何创建动态变量?
    在Python 中,动态创建变量的功能可以是一种强大的工具,尤其是在使用复杂的数据结构或算法时,Dynamic Variable Creation的动态变量创建。 Python提供了几种创造性的方法来实现这一目标。利用dictionaries 一种有效的方法是利用字典。字典允许您动态创建密钥并分...
    编程 发布于2025-07-02
  • 哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
    编程 发布于2025-07-02
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-07-02
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-07-02
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-07-02
  • Python元类工作原理及类创建与定制
    Python元类工作原理及类创建与定制
    python中的metaclasses是什么? Metaclasses负责在Python中创建类对象。就像类创建实例一样,元类也创建类。他们提供了对类创建过程的控制层,允许自定义类行为和属性。在Python中理解类作为对象的概念,类是描述用于创建新实例或对象的蓝图的对象。这意味着类本身是使用类关...
    编程 发布于2025-07-02
  • 表单刷新后如何防止重复提交?
    表单刷新后如何防止重复提交?
    在Web开发中预防重复提交 在表格提交后刷新页面时,遇到重复提交的问题是常见的。要解决这个问题,请考虑以下方法: 想象一下具有这样的代码段,看起来像这样的代码段:)){ //数据库操作... 回声“操作完成”; 死(); } ?> ...
    编程 发布于2025-07-02
  • 为什么不使用CSS`content'属性显示图像?
    为什么不使用CSS`content'属性显示图像?
    在Firefox extemers属性为某些图像很大,&& && && &&华倍华倍[华氏华倍华氏度]很少见,却是某些浏览属性很少,尤其是特定于Firefox的某些浏览器未能在使用内容属性引用时未能显示图像的情况。这可以在提供的CSS类中看到:。googlepic { 内容:url(&#...
    编程 发布于2025-07-02
  • 同实例无需转储复制MySQL数据库方法
    同实例无需转储复制MySQL数据库方法
    在同一实例上复制一个MySQL数据库而无需转储在同一mySQL实例上复制数据库,而无需创建InterMediate sqql script。以下方法为传统的转储和IMPORT过程提供了更简单的替代方法。 直接管道数据 MySQL手动概述了一种允许将mysqldump直接输出到MySQL clie...
    编程 发布于2025-07-02
  • Java中Lambda表达式为何需要“final”或“有效final”变量?
    Java中Lambda表达式为何需要“final”或“有效final”变量?
    Lambda Expressions Require "Final" or "Effectively Final" VariablesThe error message "Variable used in lambda expression shou...
    编程 发布于2025-07-02
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在银光应用程序中,尝试使用LINQ建立错误的数据库连接的尝试,无法找到以查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中,tblpersoon可能需...
    编程 发布于2025-07-02
  • 您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    在javascript console 中显示颜色是可以使用chrome的控制台显示彩色文本,例如红色的redors,for for for for错误消息?回答是的,可以使用CSS将颜色添加到Chrome和Firefox中的控制台显示的消息(版本31或更高版本)中。要实现这一目标,请使用以下模...
    编程 发布于2025-07-02

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3