Cucumber入门之_Hooks&Background

简介: Hooks &  Background   Hooks  在很多情况下,我们需要在每个scenario之前(before)和之后(after)执行某些相同的操作。比如说在测试完成后要关闭浏览器。在Cucumber中,我们可以使用hooks.

Hooks &  Background

 

Hooks 

在很多情况下,我们需要在每个scenario之前(before)和之后(after)执行某些相同的操作。比如说在测试完成后要关闭浏览器。在Cucumber中,我们可以使用hooks. 在Cucumber中,有三种不同的hooks:

 

  Before:     在每个scenario前执行

  After:       在每个scenario后执行

  AfterStep: 在每个scenario后执行

 

我们可以把这些hooks放在features文件夹下面的任何ruby文件里面,但一般推荐的做法是把它们放在features/support/hooks.rb 文件里,这样让我们更容易记住我们的代码放在哪。

 

另外,Hooks可以被定义任意次。如果在每个scenario之前有十件不同的事需要我们去处理,我们可以定义十个Before 钩子(hooks),他们会按定义的顺序去执行。

 

当我们有很多个hooks时,我们有时候可能不需要让它们全部运行,这时候我们就可以使用标签钩子(tagged hooks).

 

Tagged Hooks      

标签hooks跟一般的hooks差不多,但是它只有特定的scenario上运行。即: 跟它有相同tag的 scenario才会执行。

例:

1   Before("@foo") do
2
3     puts "This will run before each scenario tagged with @foo"
4
5   end

 

优缺点:

       优点:很显然,hooks的优点是可以在每个scenario之前或之后做一些共同的操作。

       缺点:Hooks是在Ruby文件中定义的,对于非技术人员来说是不易读的,除非case失败,否则不会有什么证据表明它们的存在。在这种情况下,我们就可以使用Background.

 

Background

当我们希望steps在feature文件里面可见时,我们可以使用background代替Before钩子,它们可以为每个scenario创建逻辑的上下文。

 

Background会在每个scenario之前执行,就像Before钩子一样。但如果存在Before 钩子,那个它们会先于background执行。

 

当我们有相同的操作时,为了遵守DRY原则,我们可以选择hooks或background。至于选择哪一种方式,取决于当它们明确的出现在feature文件里是否有价值。

 

下面看一个小示例:

目录结构:

 

testhook.feature

 1 Feature: Test how to use hooks
2 In order to learn how to use hooks
3 as a learner
4 I want to do some practice
5
6 @hotel
7 Scenario: search a hotel
8 Given I visit to hotel launch page
9
10 Scenario: search a flight
11 Given I visit to flight launch page

  在该feature文件中定义了两个scenario,第一个scenario有一个tag: @hotel(为了说明tagged hooks的用法),另一个没加tag。两个scenario都只有一个步骤,在这我们就不纠结这些了,只为演示hooks的的用法。

 

testhook.rb

1 Given /^I visit to hotel launch page$/ do
2 puts "The current page is the hotel launch page."
3 end
4
5 Given /^I visit to flight launch page$/ do
6 puts "The current page is the flight launch page."
7 end

  该文件是对feature文件的具体实现,在这两个Given中我都只是简单的打印出了一句话。

 

hooks.rb

1 Before do
2 #Before("@hotel") do #tagged hooks
3 puts "This is before hook."
4 end
5
6 After do
7 #After("@hotel") do #tagged hooks
8 puts "This is after hook."
9 end

  在该hooks文件中,我定义了before和after钩子,也都只是简单的输出一句话。注:第2,7行分别为tagged钩子,当执行它们时,只有跟它们匹配的tag的scenario前/后会执行此hook。

 

运行结果:

执行非tagged hooks:

 1 This is before hook.
2
3 The current page is the hotel launch page.
4
5 This is after hook.
6
7 This is before hook.
8
9 The current page is the flight launch page.
10
11 This is after hook.

 

执行tagged hooks:

1 This is before hook.
2
3 The current page is the hotel launch page.
4
5 This is after hook.
6
7 The current page is the flight launch page.






目录
相关文章
|
XML 存储 Android开发
Jetpack-Compose 学习笔记(六)——Compose 主题 Theme 一探究竟,换肤还能如此 Easy & Silky?(上)
Jetpack-Compose 学习笔记(六)——Compose 主题 Theme 一探究竟,换肤还能如此 Easy & Silky?(上)
133 0
|
存储 Android开发
Jetpack-Compose 学习笔记(六)——Compose 主题 Theme 一探究竟,换肤还能如此 Easy & Silky?(下)
Jetpack-Compose 学习笔记(六)——Compose 主题 Theme 一探究竟,换肤还能如此 Easy & Silky?(下)
203 0
|
前端开发
前端项目实战柒拾捌react-admin+material ui-踩坑-List的用法之actions
前端项目实战柒拾捌react-admin+material ui-踩坑-List的用法之actions
70 0
hook+ant design实现input多行编写小案例
hook+ant design实现input多行编写小案例
61 0
|
JavaScript 前端开发
【Vue 开发实战】实战篇 # 26:Ant Design Pro介绍
【Vue 开发实战】实战篇 # 26:Ant Design Pro介绍
225 0
【Vue 开发实战】实战篇 # 26:Ant Design Pro介绍
|
JavaScript 前端开发
Vue实战笔记(一) 引入Ant Design
Vue实战笔记(一) 引入Ant Design
404 0
|
前端开发
react实战笔记77:引入fontawesome
react实战笔记77:引入fontawesome
77 0
react实战笔记77:引入fontawesome
|
缓存 JavaScript 前端开发
手写简易版flexible.js以及源码分析
我们的移动端布局通常会有rem结合媒体查询的实现,但是,淘宝有这样的一个flexible.js框架,根据不同的width给网页中html根节点设置不同的font-size,大大提高了我们的开发效率,今天阿牛便带你手写一个简易版flexible.js并解读,了解他的大致原理。
482 0
手写简易版flexible.js以及源码分析
|
前端开发
前端学习案例-ant design model实现图片预览
前端学习案例-ant design model实现图片预览
256 0
|
前端开发
React工作55:ant design spin
React工作55:ant design spin
230 0