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.






目录
相关文章
|
5月前
|
前端开发 JavaScript 测试技术
Jest与React Testing Library:前端测试的最佳实践
Jest和React Testing Library是React应用测试的核心工具。安装相关依赖后,在`jest.config.js`中配置Jest。测试时,编写描述性测试用例,使用`render`、`fireEvent`和`screen`来检查组件行为。Jest提供模拟功能,如模拟API调用。测试组件交互性时,模拟用户行为并验证状态变化。确保覆盖边缘情况,使用代码覆盖率报告评估测试完整性,并将测试集成到CI流程中。
83 1
|
6月前
|
传感器 算法 搜索推荐
stylus使用方法
stylus使用方法
54 0
|
6月前
Ant Design(antd)表单校验的一些注意事项
Ant Design(antd)表单校验的一些注意事项
134 0
|
前端开发
前端项目实战柒拾捌react-admin+material ui-踩坑-List的用法之actions
前端项目实战柒拾捌react-admin+material ui-踩坑-List的用法之actions
70 0
|
前端开发
前端项目实战壹佰零肆react-admin+material ui-踩坑-List的用法之queryOptions
前端项目实战壹佰零肆react-admin+material ui-踩坑-List的用法之queryOptions
71 0
hook+ant design实现input多行编写小案例
hook+ant design实现input多行编写小案例
61 0
|
前端开发
前端项目实战肆拾伍-​react-admin+material ui-踩坑-layout
前端项目实战肆拾伍-​react-admin+material ui-踩坑-layout
51 0
dva和Umi中两个小用法
dva和Umi中两个小用法
209 0
|
前端开发
前端项目实战227-ant design 5.0中async和await
前端项目实战227-ant design 5.0中async和await
110 0
|
前端开发
前端项目实战199-ant design tab 4.2.3之前用法
前端项目实战199-ant design tab 4.2.3之前用法
73 0