Cucumber入门之Gherkin

Posted Eimme

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Cucumber入门之Gherkin相关的知识,希望对你有一定的参考价值。

1.Gherkin简介:

Cucumber是一个解释程序,就像ruby命令执行解释 .rb文件里的Ruby代码一样,Cucumber用来执行解释 .feature文件里的Gehrkin代码。Gherkin是一种简单的英语文本语言,它有助于工具--Cucumber解释和执行测试脚本。

         如前所述,已经看到BDD在创建测试脚本时结合了不同的前景。它可以是开发前瞻性,业务前景等。也就是说,我们将需要来自不同社区的人,如开发人员,项目经理,产品所有者和测试人员,同时开发测试脚本。由于这些人不属于同一类别,因此存在不使用公共语言用于测试脚本概念化的风险。这是Gherkins的演变点

         Gherkin提供了英语文本中的公共关键字集,可以由不同社区的人使用,但是以测试脚本的形式获得相同的输出。

2. 关键字:

当你编写一个feature文件的时候,会用到很多Gherkin语言里特定的关键字,主要包括下这面些:

  • Feature

  • Background

  • Scenario

  • Scenario outline

  • Scenarios (or examples)

  • Given

  • When

  • Then

  • And (or but)

  • | (用来定义表格)

  • """ (定义多行字符串)

  • # (注释) 

  我们可以在关键字后面写任何我们想写的东西。关键字Given, When, Then, And 和 But用来指示一个场景中的步骤。

     每一个feature文件必须以关键字Feature开始,且紧跟着一个冒号和一个描述。这个描述可以在很多行上,但一般来说比较好的模式是写一句简短的概述,紧接着在下一行对此进行一个简明的描述。比如: 

       Feature: Book flight

              In order to book a flight

              As a user

              I want to find the cheapest flight 

       当然有一点需要指出的是,Cucumber并不关心你在这里写了什么。它只是简单的忽略这些代码直到它碰到关键字Background, Scenario 和 Scenario Outline. 我们写这些的目的仅仅是为了沟通和交流。

3. Scenarios/Steps/The cucumber Command

  1. Scenario:一个feature文件里面可以有很多个Scenario,一个Scenario就是一个具体的你想要测试的功能点,一个Scenario又是由很多个步骤(Steps)组成的。Scenario明确的描述我们期望的程序的行为,且方便不同职位的人员进行沟通,因为你只要看到一个Scenario,很容易就知道它想做什么。

一个Scenario的第一部分是Scenario关键字后面紧跟一个冒号和一个对应该场景的描述。如下:

       Feature: Book flight

              In order to book a flight

              As a user

              I want to find the cheapest flight       

        Scenario: Successful booking flight

 

  2. Steps:每个Scenario都可以使用任意数量的步骤来描述任何发生在该场景里的事情,一个步骤通常是一行单独的文本并且由以下这些关键字开头:Given,When,Then,And and But. 如下:(注意:步骤后面不需要跟冒号)

       Feature: Book flight

              In order to book a flight

              As a user

              I want to find the cheapest flight       

        Scenario: Successful booking flight

               Given I visit a website to book flight

  3. The cucumber Command: 一旦我们写好了一个feature文件,我们就可以使用 命令来运行它。如果命令后不跟任何东西的话,那么它会执行所有的.feature文件。如果我们只想运行某一个.feature文件,我们可以使用命令

4.Given/When/Then/And/But

  a) Given:表示scenario中我们接受/认为是真的东西,它将为后面的when(事件/操作)和Then(输出)提供背景/上下文;如:Given I visit a website

  b)When:表示scenario中的事件或动作;如:When I click the submit button.; 一般我们喜欢在一个scenario中只有一个事件或动作,因为这样容易理解scenario的目的且容易找到错误当失败的时候;

  c) Then:表示预期的输出;

  d) And/ But: 我们可以使用And 和 But 作为Given/When/Then的同义词,如:” ” 这里的And就是Given的意思;再如:”,” 这里的But就是Then的意思;

例:

  Scenario: transfer money (declarative)

  Given I have $100 inchecking

  And I have $20 insavings

  When I transfer $15 from checking to savings

  Then I should have $85 inchecking

  And I should have $35 insavings

5. Tags

  正如前面提到的一个.feature 文件里面可以有很多scenario组成。如果我们运行了一个包含有很多个scenario的feature文件时,它会执行这个文件里面所有的 scenario;但是有的时候我们可能只想运行某一个/些特别的scenario时,这时我们可以使用Tags; 

在Cucumber里Tag看上去和Ruby的实例变量比较像。如@wip, @foo…可以在Feature或Scenario关键字前给feature或scenario添加任意数量的tags,如: 

  @approved @book_flight

  Feature: Book flight 

          @wip

          Scenario: Book a flight on web

  一个Scenario会继承指定给Feature的tags,所以在上面的例子中,Scenario有三个tags:@approved @book_flight @wip.  然后我们就可以使用命令:cucumber  --tags tag_name来运行我们想运行的那部分Scenario.如:cucumber --tags @wip 

  此外,--tags还支持复杂的表示示,包括: AND,OR和NOT,如下:

  cucumber --tags  (foo,)bar

  #@foo || @bar        运行所有包含@foo OR @bar的scenarios

  cucumber --tags @foo --tags @bar

  # @foo && @bar   运行所有包含@foo AND @bar的scenarios

  cucumber --tags ~@dev

  #!@dev                  运行所有不包含@dev的scenario

  cucumber --tags @foo,~@bar --tags @baz

  # (@foo || !@bar) && @baz       

(摘自http://www.cnblogs.com/puresoul/archive/2011/12/28/2305160.html)

以上是关于Cucumber入门之Gherkin的主要内容,如果未能解决你的问题,请参考以下文章

自动化测试工具Cucumber的简单介绍,入门篇

BDD框架之Cucumber初探

Cucumber 之Gherkin

测试工程师进阶,从0-1学习Cucumber之基于behave自动化测试教程

测试工程师进阶,从0-1学习Cucumber之基于behave框架自动化测试教程

测试工程师进阶,从0-1学习Cucumber之基于behave框架自动化测试教程