在本教程中,我们将向您介绍Gherkin - BDD语言(业务驱动开发)。我们将尽力详细回答这些问题
原文点击这里
免费英语视频教程可见微信公众号:【软测小生】里面,请关注公号更新相关文章和视频资源。
另外有一个中国团队在做类似的事情,详情可见:http://cuketest.com/zh-cn/
接下来,让我们从一些细节开始学习。
在深入研究Gherkin之前,有必要了解跨项目不同领域的公共语言的重要性和需求。我所说的不同领域是指客户、开发人员、测试人员、业务分析师和管理团队。让我们先讨论开发项目中的常见问题,然后再讨论解决方案,在此过程中,我们将遇到对公共语言的需求。
插播:
Gherkin(剧本语法)是用于编写Cucumber、Specflow或类似的BDD框架规范的语言。这是一种业务人员可读懂的,特定领域的语言,它可以让你描述软件的行为,而不用详细说明如何实现这个行为。有几个约定:
假设您是技术团队(开发人员和测试人员)的一部分,并且您有一个与业务团队(业务所有者和业务分析师)协作的任务。您必须提出项目的需求,这些需求将是你的开发团队将要实现的,而测试团队将进行测试。此外,你必须在你的电子商务平台上做一个小的搜索功能,这个功能将允许用户在您的网站上搜索产品。
正如我们在经验中可能都遇到过的,业务团队给出的需求是非常粗糙和基本的。例如,在这个场景中,我们可能会得到以下要求:
3. 功能需求
3.1 搜索功能
3.1.1 用户应该能够搜索产品
3.1.2 只显示与搜索字符串相关的产品。
正如我们所看到的,这些需求很好,也很有用,但并不准确。它们描述了系统的广泛行为,但没有指定系统的具体行为。让我通过分析第一个需求来说明它,第一个需求说用户应该能够搜索产品,但是它没有指定以下内容:
-搜索字符串的最大可搜索长度是多少?
-如果用户搜索无效的产品,搜索结果应该是什么?
-什么是可以用来搜索的有效字符?
*以及应用程序的一些更详细的行为。
通常在一个项目中,我们最终会向业务团队提出上述问题,并得到答复,大多数答复会到达项目文档,但不幸的是,这些答复会在电子邮件和电话对话中丢失。并且这些答复也可以解释,例如:
问业务负责人:如果用户搜索无效的产品,搜索结果应该是什么?
来自业务负责人的回复:无效的产品搜索应该在搜索页面上显示以下文本:没有找到产品(No product found)。
我们可以从业务团队那里得到问题的答案,但也可以通过以下方式进行解释或提出疑问:
-无效产品的定义是模糊的,不同的团队成员会以不同的方式解释。一个人可能认为一个无效的产品不存在于库存中,而其他团队成员可能认为一个无效的产品是一个拼写错误。
-业务团队的回答是“没有找到产品(No product found)”的文本应该显示在页面上。它是否说应该为用户提供一个新的搜索选项? 或者应该为用户提供一个相关的 / 类似的搜索选项?
这些是系统中引入有误差的精确点。此外,如果我们分析第二个疑问,我们将看到用户业务团队希望向用户提供一个新的搜索选项和 相关或者类似的搜索选项。然而,当被问到这个问题时,他们却想不出这个情景。因此,在上面的例子中发生的是:
现在,让我们改进业务团队给出的第一个需求,并尝试使其更加精确:
“当用户在没有拼写错误的情况下搜索库存中的产品名称时。所有名称相似的产品均应展示”
“当用户在没有拼写错误的情况下搜索库存中的产品名称时。搜索结果应先显示准确的匹配项,然后再显示相似的匹配项。”
在这里,我们可以看到需求变得多么清晰,有了这些清晰的需求,我们就可以对系统进行更多的思考。例如:在第二个需求的情况下,读完后我们可能会想到其他的场景,比如:
我们已经迫使客户考虑细节。有了这种改进的思想,业务团队就有了更精细的需求。这进而减少了项目中的模糊性,并将通过减少错误实现的数量使开发人员和测试人员的工作变得简单。此外,您还可以看到,现在每个需求都记录了应用程序的一个确切行为。这意味着它本身可以被看作是一个需求文档。
好吧,通过上面的例子或练习,我们可以总结如下:
为了解决这些问题,Gherkin(小黄瓜)应运而生。Gherkin是一种简单、轻量级和结构化的语言,它使用常规的口语来描述需求和场景。我们所说的常规口语指的是英语、法语和大约30多种语言。(包括中文)
由于Gherkin是一种结构化语言,它遵循一些语法,让我们先来看一个用小黄瓜描述的简单场景。
Feature:为用户搜索功能 (中文:功能)
这个特性非常重要,因为它允许用户过滤产品
Scenario: 当用户搜索库存中的产品名称时,没有拼写错误。应显示所有名称相似的产品 (中文:场景)
Given 用户在www.myshopingsite.com的主页上 (中文:假如)
When 用户搜索笔记本电脑时 (中文:当)
Then 搜索页面应该更新笔记本电脑的列表 (中文:然后)
Gherkin包含一组关键字,这些关键字定义了场景的不同前提。正如我们在上面看到的彩色部分是关键字。我们稍后会详细讨论gherkin测试结构,但需要注意的重点是:
后续会更新更多文章,上文种可能有些许错误,若有请指正,谢谢