Merge pull request #29869 from wxy/20230207.3-️-How-the-Gherkin-language-bridges-the-gap-between-customers-and-developers

RP:20230207.3 ️ how the gherkin language bridges the gap between customers and developers
This commit is contained in:
Xingyu.Wang 2023-08-13 10:10:03 +08:00 committed by GitHub
commit e9752a23e0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -3,20 +3,26 @@
[#]: author: "David Blackwood https://opensource.com/users/david-blackwood" [#]: author: "David Blackwood https://opensource.com/users/david-blackwood"
[#]: collector: "lkxed" [#]: collector: "lkxed"
[#]: translator: "geekpi" [#]: translator: "geekpi"
[#]: reviewer: " " [#]: reviewer: "wxy"
[#]: publisher: " " [#]: publisher: "wxy"
[#]: url: " " [#]: url: "https://linux.cn/article-16088-1.html"
Gherkin 语言如何弥合客户和开发人员之间的差距 Gherkin 语言如何弥合客户和开发人员之间的差距
====== ======
与软件开发人员沟通通常是一项繁重的任务,尤其是当人们缺乏技术知识和技术词汇时。这就是为什么项目经理经常使用[用户故事][1]和多功能系统隐喻。 ![][0]
> Gherkin 语法可以帮助你思考技术事务的过程,然后帮助你将其转化为程序员逻辑的形式写下来。
与软件开发人员沟通通常是一项繁重的任务,尤其是当人们缺乏技术知识和技术词汇时。这就是为什么项目经理经常使用 [用户故事][1] 和多功能系统隐喻。
你可以利用旨在促进项目利益相关者和开发人员之间讨论的技术,进一步协助沟通。 你可以利用旨在促进项目利益相关者和开发人员之间讨论的技术,进一步协助沟通。
### Cucumber 框架 ### Cucumber 框架
Cucumber 是一个开源框架,可以使用易于编写的通用语言创建自动化软件测试。它基于[行为驱动开发 (BDD)][2] 的概念,该概念规定创建软件应定义用户希望应用在特定条件成立时如何表现。 Cucumber 是一个开源框架,可以使用易于编写的通用语言创建自动化软件测试。它基于 [行为驱动开发BDD][2] 的概念,该概念规定创建软件应定义用户希望应用在特定条件成立时如何表现。
LCTT 译注Gherkin 和 Cucumber 都是黄瓜,其中 Gherkin 一种用来腌制的小黄瓜。顺便说一句,黄瓜原名胡瓜,因其由汉朝张骞出使西域时带回,后因石勒禁称“胡”字,更名为黄瓜。)
Cucumber 框架并不是现代意义上的“技术”。它不是位和字节的集合。相反,它是一种用自然语言(在本文中为英语,但到目前为止 Gherkin 已被翻译成 70 多种语言)的写作方式。使用 Cucumber 框架时,你不需要知道如何读取或编写代码。你只需要能够写下你对工作方式的想法即可。你还应该使用一组特定术语和指南来记录你希望技术如何为你服务。 Cucumber 框架并不是现代意义上的“技术”。它不是位和字节的集合。相反,它是一种用自然语言(在本文中为英语,但到目前为止 Gherkin 已被翻译成 70 多种语言)的写作方式。使用 Cucumber 框架时,你不需要知道如何读取或编写代码。你只需要能够写下你对工作方式的想法即可。你还应该使用一组特定术语和指南来记录你希望技术如何为你服务。
@ -26,30 +32,30 @@ Cucumber 使用 Gherkin 作为定义用例的方法。它主要用于生成明
这是一个例子: 这是一个例子:
``` 功能:活期账户持有人取款
Feature: The Current Account Holder withdraws money 场景:有关账户并不缺少资金
Scenario: The account in question is not lacking in funds 假如账户余额为 200 英镑
Given that the account balance is £200 借记卡有效
And the debit card is valid 取款机里有足够的钱
And the cash machine contains enough money 当活期账户持有人申请 50 英镑时
When the Current Account Holder requests £50 则取款机支付 50 英镑
Then the cash machine dispenses £50 账户余额为 150 英镑
And the account balance is £150 借记卡被退回
And the debit card is returned
```
正如你所看到的,这是一个非常具体的场景,其中假设用户请求 50 英镑,ATM 提供 50 英镑并相应地调整用户的帐户余额。此场景只是 ATM 用途的一部分,它仅代表人与提款机交互的特定组成部分。当程序员被赋予对机器进行编程以响应用户请求的任务时,这清楚地表明了涉及哪些因素。 正如你所看到的,这是一个非常具体的场景,其中假设用户请求 50 英镑,取款机提供 50 英镑并相应地调整用户的帐户余额。此场景只是取款机用途的一部分,它仅代表人与取款机交互的特定组成部分。当程序员被赋予对机器进行编程以响应用户请求的任务时,这清楚地表明了涉及哪些因素。
#### Gherkin 关键字是什么? #### Gherkin 关键字是什么?
Gherkin 语法使用五个不可或缺的语句来描述执行任务所需的操作: Gherkin 语法使用五个不可或缺的语句来描述执行任务所需的操作:
- **Feature**:表示任何给定软件功能的高层次描述 - <ruby>功能<rt>Feature</rt></ruby>:表示任何给定软件功能的高层次描述
- **Scenario**描述具体_示例_ - <ruby>场景<rt>Scenario</rt></ruby>描述具体_示例_
- **Given**:解释系统的初始上下文 - <ruby>假如<rt>Given</rt></ruby>:解释系统的初始上下文
- **When**:指定事件或操作 - <ruby><rt>When</rt></ruby>:指定事件或操作
- **Then**:描述预期输出或结果 - <ruby><rt>Then</rt></ruby>:描述预期输出或结果
- **And (或者 but)**:增加文本流畅性 - <ruby>而且<rt>And</rt></ruby>(或者 <ruby>但是<rt>But</rt></ruby>):增加文本流畅性
LCTT 译注这些关键字可以使用任何语言请参照https://cucumber.io/docs/gherkin/languages/
通过使用这些简单的关键字,客户、分析师、测试人员和软件程序员能够使用所有人都能识别的术语来交换想法。 通过使用这些简单的关键字,客户、分析师、测试人员和软件程序员能够使用所有人都能识别的术语来交换想法。
@ -57,20 +63,20 @@ Gherkin 语法使用五个不可或缺的语句来描述执行任务所需的操
更好的是_Gherkin 要求也是可执行的_。这是通过将每个关键字映射到其预期且明确说明的功能来完成的。因此为了与上面的示例保持一致任何已经实现的内容都可以自动显示为绿色 更好的是_Gherkin 要求也是可执行的_。这是通过将每个关键字映射到其预期且明确说明的功能来完成的。因此为了与上面的示例保持一致任何已经实现的内容都可以自动显示为绿色
``` 当活期账户持有人申请 50 英镑时
When the Current Account Holder requests £50* 则取款机支付 50 英镑
Then the cash machine dispenses £50* 账户余额为 150 英镑
And the account balance is £150 借记卡被退回
And the debit card is returned
```
通过扩展Gherkin 使开发人员能够将需求转换为可测试的代码。在实践中,你可以使用特定的短语来检查你的软件方案! 如果你当前的代码无法正常工作,或者新的更改意外导致软件错误(或两个或三个),那么你可以轻松查明问题,然后再继续修复它们。 通过扩展Gherkin 使开发人员能够将需求转换为可测试的代码。在实践中,你可以使用特定的短语来检查你的软件方案!如果你当前的代码无法正常工作,或者新的更改意外导致软件错误(或两个或三个),那么你可以轻松查明问题,然后再继续修复它们。
### 结论 ### 结论
得益于 Gherkin 语法,你的客户将不再陷入困境。你可以弥合企业和开发人员之间的鸿沟,并比以往更有信心地交付出色的产品。 得益于 Gherkin 语法,你的客户将不再陷入困境。你可以弥合企业和开发人员之间的鸿沟,并比以往更有信心地交付出色的产品。
通过访问 [Cucumber 网站][3]或其 [Git 仓库][4]了解有关 Gherkin 的更多信息。 通过访问 [Cucumber 网站][3] 或其 [Git 仓库][4] 了解有关 Gherkin 的更多信息。
*题图MJ/b717cd4f-0a6b-4b28-a895-b9688b289551*
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
@ -79,7 +85,7 @@ via: https://opensource.com/article/23/2/gherkin-language-developers
作者:[David Blackwood][a] 作者:[David Blackwood][a]
选题:[lkxed][b] 选题:[lkxed][b]
译者:[geekpi](https://github.com/geekpi) 译者:[geekpi](https://github.com/geekpi)
校对:[校对者ID](https://github.com/校对者ID) 校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出 本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
@ -89,3 +95,4 @@ via: https://opensource.com/article/23/2/gherkin-language-developers
[2]: https://opensource.com/article/19/2/behavior-driven-development-tools [2]: https://opensource.com/article/19/2/behavior-driven-development-tools
[3]: https://cucumber.io/docs/gherkin/ [3]: https://cucumber.io/docs/gherkin/
[4]: https://github.com/cucumber/docs [4]: https://github.com/cucumber/docs
[0]: https://img.linux.net.cn/data/attachment/album/202308/13/095911rawwca1qfjfhjooj.jpg