Cucumber入门之Gherkin

1.Gherkin简介:

Cucumber是一个解释程序,就像ruby命令执行解释 .rb文件里的Ruby代码一样,Cucumber用来执行解释 .feature文件里的Gehrkin代码。

Gherkin在英语中是腌制的小黄瓜的意思,

Gherkin语言编写的测试步骤,就像一个一个腌制的小黄瓜一样,竖向排列着,case清清楚楚,一目了然。

 

 

 

 

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文件,我们就可以使用 cucumber 命令来运行它。如果cucumber命令后不跟任何东西的话,那么它会执行所有的.feature文件。如果我们只想运行某一个.feature文件,我们可以使用命令cucumber features\feature_name

 

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的同义词,如:”Given x, And y,” 这里的And就是Given的意思;再如:”Then x, But not y,” 这里的But就是Then的意思;

例:

 

  Scenario: LSH C2696.1: Ingest 1st party data - full in PELID tenant
    Given I have a LSH source connection to SOURCE_GCS
    And I have a LSH destination connection to "source_bucket" from config "Mutual"
    And a source file named "lsh/1P/full_CL_tenant-2020090703_20200910-170001_2020090703_PEL.csv"
    And a source ok file named "lsh/1P/full_CL_tenant-2020090703_20200910-170001_2020090703_PEL.csv.ok"
    And I use "pel.1p.manual_full_ingestion_td" name for destination file "Ingestion"
    And I use "pel.1p.manual_full_ingestion_td_ok" name for destination ok file "Ingestion"
    When I upload LSH source file into destination
    And  I upload LSH source ok file into destination
    Then I should see that LSH source and uploaded files have the same size

  

 

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    

posted @ 2021-03-02 16:30  巴黎爱工作  阅读(526)  评论(0编辑  收藏  举报