”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 一起使用 AskUI 和 Cucumber

一起使用 AskUI 和 Cucumber

发布于2024-07-31
浏览:802

一起使用 AskUI 和 Cucumber

通过以 Gherkin 等结构化格式定义系统的行为,行为驱动开发 (BDD) 使团队能够弥合利益相关者、测试人员和开发人员之间的差距,避免误解并减少返工。作为一种协作方法,BDD 鼓励各方从一开始就共同努力,确保每个人都参与
同一页面并且准确捕获了需求。

在此过程中,Cucumber 是一种用于实现 BDD 的流行工具,使团队能够编写清晰、可执行的测试,以确保系统按预期运行。

在这篇博文中,我们将向您展示如何将 Cucumber 与 AskUI 结合设置,以使用 BDD 原则定义 AskUI 工作流程。

Gif showing the whole workflow. Open new tab in Google Chrome browser, typing in the AskUI Practice Page URL and pressing enter. Then the practice page is opened

先决条件

  • 在您的系统(Windows、Linux、macOS)上安装并配置了 AskUI

  • 初始化后删除asgui_example/my-first-askui-test-suite.test.ts

准备设置

Cucumber 与 AskUI 的默认设置(版本 0.20.3)还不能很好地配合。为了让 AskUI 与 Cucumber 良好配合,您需要做两个小准备,因为 AskUI 使用 Jest 作为其运行器。

1.更改Jest的testEnvironmentOptions

在文件asgui_example/helpers/jest.config.ts中,您必须禁用运行报告中包含的代码。您可以通过添加 testEnvironmentOptions 属性并将 addCodeInReport 属性设置为 false 来实现此目的。

const config: Config.InitialOptions = {
  ...
  testEnvironment: '@askui/jest-allure-circus',
  testEnvironmentOptions: {
    addCodeInReport: false
  },
};
...

2. 告诉 Jest 在哪里可以找到步骤定义的实现

另外,在asgui_example/helpers/jest.config.ts中,您需要扩展默认的testMatch属性。它必须包含以 step.ts 结尾的文件,因为我们将在那里存储实现。

...
const config: Config.InitialOptions = {
  ...
  testEnvironment: '@askui/jest-allure-circus',
  testEnvironmentOptions: {
    addCodeInReport: false
  },
  testMatch: [ "**/__tests__/**/*.[jt]s?(x)", "**/?(*.) (spec|test|step).[jt]s?(x)" ]
};
...
s?(x)", "**/?(*.) (spec|test|step).[jt]s?(x)" ] }; ...

安装 jest-cucumber


将 Jest 与 Cucumber 一起使用的最简单方法是 npm-package jest-cucumber。让我们使用以下命令安装它:

npm install --save-dev jest-cucumber
npm install --save-dev jest-cucumber

创建基本特征文件

创建一个文件夹 features,并在其中创建一个 Feature
文件 NavigateToWebsite.feature

npm install --save-dev jest-cucumber
project_root/ ├─asgui_example/ ├─ 特点/ ├─ NavigateToWebsite.feature ├─ 节点模块/ ├─ ...

将以下基本功能
写入此文件:

npm install --save-dev jest-cucumber
功能:导航到网站 场景:在浏览器地址栏中输入正确的URL 鉴于我在 Google 搜索页面上 当我输入 AskUI 练习页面的 URL 时 然后我就会登陆网页

创建步骤定义实施


创建步骤定义文件asgui_example/navigate-to-url.step.ts,其中每个测试映射到特定场景。

npm install --save-dev jest-cucumber
从'jest-cucumber'导入{defineFeature,loadFeature}; 从 './helpers/askui-helper' 导入 { aui } ; // 加载特征文件 const feature = loadFeature('features/NavigateToWebsite.feature'); 定义功能(功能,测试=> { // 映射到功能文件中的“场景” test('在浏览器地址栏中输入正确的 URL', ({给定, 当, 然后 }) => { Give('我在 Google 搜索页面', async () => { 等待 aui.moveMouse(500, 500).exec(); 等待 aui.mouseLeftClick().exec(); 等待 aui.pressTwoKeys('command', 't').exec(); }); when('我输入 AskUI 练习页面的 URL', async () => { 等待 aui.typeIn('https://askui.github.io/askui-practice-page/').textfield().exec(); 等待 aui.pressKey('enter').exec(); }); then('我将登陆网页', async () => { wait aui.expect().text('欢迎来到AskUI练习页面').exists().exec(); }); }); });

运行工作流程


全屏打开浏览器并启动工作流程:

npm install --save-dev jest-cucumber
npm run asgui

您应该看到工作流程运行将打开一个新选项卡并导航到 AskUI 的练习页面。

结论

将 AskUI 与 Cucumber 相结合使您能够以 BDD 风格编写 AskUI 工作流程。像真正的人类用户一样执行测试将使测试对于每个利益相关者来说更加现实。

版本声明 本文转载于:https://dev.to/askui/use-askui-and-cucumber-together-2803?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2024-12-21
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-12-21
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    编程 发布于2024-12-21
  • 如何在 C++ 宏中实现可选参数以进行代码定制?
    如何在 C++ 宏中实现可选参数以进行代码定制?
    使用 C 宏自定义参数宏是 C 编程的基本方面,允许代码自定义和灵活性。一个常见的要求是能够在宏中定义可选参数。可选参数考虑以下示例,其中我们有一个打印字符串的宏: #define PRINT_STRING(message) PrintString(message, 0, 0)该宏接受一个强制参数,...
    编程 发布于2024-12-21
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-21
  • 如何创建 100% 高度并隐藏滚动条的全屏 Iframe?
    如何创建 100% 高度并隐藏滚动条的全屏 Iframe?
    全屏iframe高度为100%查询:是否普遍支持iframe height=100%跨浏览器?当使用XHTML1作为doctype时,高度为100%的iframe是否会占据页面剩余高度(不包括顶部的50px固定高度框架)?另外,如何在自动设置 iframe 高度的同时完全隐藏滚动条?响应:虽然可以采...
    编程 发布于2024-12-21
  • 如何解决 VS2010 中混合 C 和 C++ 项目中的 LNK2001 链接器错误?
    如何解决 VS2010 中混合 C 和 C++ 项目中的 LNK2001 链接器错误?
    解决 VS2010 中混合 C 和 C 项目中的链接器错误问题描述将 C 代码集成到不同 VS2010 项目中的 C 项目中导致从 C 代码调用 C 函数时出现链接错误。该错误标识为 LNK2001,与未解析的外部符号有关。解决方案要纠正此问题,请遵循特定准则来确保代码库的正确组织: 模块化代码:每...
    编程 发布于2024-12-21
  • 如何在.NET MySqlCommand中启用MySQL用户定义变量?
    如何在.NET MySqlCommand中启用MySQL用户定义变量?
    在.NET MySqlCommand中使用MySql用户定义变量在.NET MySqlCommand中执行涉及用户定义变量的MySQL语句时,您可能会遇到致命错误。要解决此问题,请按照下列步骤操作:在您的代码中,您有一条 MySQL 语句,用于设置用户定义的变量“@a”,然后选择其值。但是,您在尝试...
    编程 发布于2024-12-21
  • 如何在 Windows 版 XAMPP 中升级 PHP:分步指南
    如何在 Windows 版 XAMPP 中升级 PHP:分步指南
    在 XAMPP for Windows 中升级 PHP:综合指南在 XAMPP for Windows 中升级 PHP 对于维护安全性、功能和性能至关重要您的网络应用程序的兼容性。本指南将提供成功升级 PHP 的分步过程。从 PHP 官方网站降级您可能尝试过直接下载最新的 PHP来自 PHP 官方网...
    编程 发布于2024-12-21
  • 如何可靠地确定我的 PHP 脚本是从命令行运行还是通过 HTTP 运行?
    如何可靠地确定我的 PHP 脚本是从命令行运行还是通过 HTTP 运行?
    确定 PHP 中的命令行执行还是 HTTP 执行PHP 脚本开发中的一个常见任务是确定执行环境的类型,无论是该脚本通过命令行或通过 HTTP 运行。这些知识对于制定输出格式决策和相应地自定义行为至关重要。检查 SERVER['argc'] 是否存在的传统方法并不可靠,因为即使使用“A...
    编程 发布于2024-12-21
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-12-21
  • 如何增加 Web 表单的最大 POST 数据大小?
    如何增加 Web 表单的最大 POST 数据大小?
    最大化后期数据处理以增强表单提交在 Web 开发中,经常会遇到需要处理大量数据(例如用户输入或文件上传)的情况。通过表单元素提交。处理大量发布数据对于确保网站的无缝运行至关重要。但是,可能存在限制最大帖子大小的限制,从而导致意外错误并阻碍数据提交。为了应对这一挑战,必须探索增加 Web 应用程序中最...
    编程 发布于2024-12-21
  • 如何在 C++ 中定义静态 const std::string 成员?
    如何在 C++ 中定义静态 const std::string 成员?
    定义 const std::string 类型的静态数据成员在 C 中,定义 std::string 类型的私有静态 const 成员在类内使用类内初始化,如下所示,不符合C标准:class A { private: static const string RECTANGLE = ...
    编程 发布于2024-12-21
  • 使用 Uvicorn 在 FastAPI 中发出并发 HTTP 请求时如何避免“ConnectionClosed”错误?
    使用 Uvicorn 在 FastAPI 中发出并发 HTTP 请求时如何避免“ConnectionClosed”错误?
    在 Uvicorn/FastAPI 中发出 HTTP 请求处理使用 FastAPI 和 Uvicorn 构建的 HTTP 端点时,通常会从外部 API 请求数据。但是,在处理多个并发请求时,可能会出现“can't handle event type ConnectionClosed when...
    编程 发布于2024-12-21
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-12-21

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

Copyright© 2022 湘ICP备2022001581号-3