Cucumber Hooks

http://www.itpub.net/thread-1626060-1-1.html

https://github.com/cucumber/cucumber/wiki/tags

https://zsoltfabok.com/blog/2012/09/cucumber-jvm-hooks/

https://github.com/cucumber/cucumber/wiki/Hooks

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).



Tags

Eddie Curtis edited this page on 31 May 2017 ·  33 revisions

Tags are a great way to organise your features and scenarios. Consider this example:

@billing
Feature: Verify billing

  @important
  Scenario: Missing product description

  Scenario: Several products

A Scenario or feature can have as many tags as you like. Just separate them with spaces:

@billing @bicker @annoy
Feature: Verify billing

Tag Inheritance

Any tag that exists on a Feature will be inherited by ScenarioScenario Outline or Examples.

Running a subset of scenarios

You can use the --tags option to tell Cucumber that you only want to run features or scenarios that have (or don’t have) certain tags. Examples:

cucumber --tags @billing            # Runs both scenarios
cucumber --tags @important          # Runs the first scenario
cucumber --tags ~@important         # Runs the second scenario (Scenarios without @important)

cucumber --tags @billing --tags @important    # Runs the first scenario (Scenarios with @important AND @billing)
cucumber --tags @billing,@important           # Runs both scenarios (Scenarios with @important OR @billing)

(Another way to “filter” what you want to run is to use the file.feature:line pattern or the --scenario option as described in Running Features).

Tags are also a great way to “link” your Cucumber features to other documents. For example, if you have to deal with old school requirements in a different system (Word, Excel, a wiki) you can refer to numbers:

@BJ-x98.77 @BJ-z12.33
Feature: Convert transaction

Another creative way to use tags is to keep track of where in the development process a certain feature is:

@qa_ready
Feature: Index projects

Tags are also used in Tagged Hooks, which let you use tags to define what Before and Afterblocks get run for what scenarios.

Logically ANDing and ORing Tags

As you may have seen in the previous examples Cucumber allows you to use logical ANDs and ORs to help gain greater control of what features to run.

Tags which are comma separated are ORed:

Example: Running scenarios which match @important OR @billing

cucumber --tags @billing,@important

Tags which are passed in separate --tags are ANDed

Example: Running scenarios which match @important AND @billing

cucumber --tags @billing --tags @important

You can combine these two methods to create powerful selection criteria:

Example: Running scenarios which match: (@billing OR @WIP) AND @important

cucumber --tags @billing,@wip --tags @important

Example: Skipping both @todo and @wip tags

cucumber --tags ~@todo --tags ~@wip

You can use this tag logic in your Hooks as well.

This feature was originally added in version 0.4.3. The logical behaviour of tags was later reversed in version 0.6.0.

Overriding the tag filters from a profile

It is currently not possible to override the tag filters from a profile.

The default profile, for example, includes a --tags ~@wip filter. But what if you want to use everything from the default profile except the --tags ~@wip portion?

You might think you could just append something like this to the command line to “undo” the --tags from the profile: --tags @wip,~@wip (anything either tagged with @wip or not tagged with @wip)

But because that is effectively doing an “and” between --tags ~@wip and --tags @wip,~@wip, it doesn’t match any scenarios.

How can we override the tag filter then?

Tag limits and WIP

If you’re following Kanban principles, you want to limit the work in progress (WIP). The idea is that the fewer features or scenarios that being worked on simultaneously, the quicker you’ll be able to implement new features.

Cucumber can enforce this using tag limits. Here is an example:

cucumber --tags @dev:2,@qa:3

This will make cucumber fail if you have more than 2 @dev tags or more than 3 @qa tags, even if each of your scenarios pass individually.

Used in conjunction with the --wip switch you can set up your project to enforce the WIP limits of your team.

Special Tags

@allow-rescue: Turns off Cucumber’s exception capturing for the tagged scenario(s). Used when the code being tested is expected to raise and handle exceptions.

@javascript: Uses a javascript-aware system to process web requests (e.g., Selenium) instead of the default (non-javascript-aware) webrat browser.

@no-txn: Turns off transactions. See Browsers and Transactions.



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值