定制 allure-framework/allure-behat 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

allure-framework/allure-behat

最新稳定版本:1.1.0

Composer 安装命令:

composer require allure-framework/allure-behat

包简介

Allure Behat integration

README 文档

README

This is a Behat extension with Formatter that produces report data for Allure Report test reporting tool.

Installation

To install using Composer simply add "allure-framework/allure-behat" to composer.json:

...
"require": {
...
    "allure-framework/allure-behat": "~2.0.0",
...
},
...

Usage

To enable this extension in Behat, add it to extensions section of your behat.yml file To use Allure formatter, add allure to your list of formatters in name

  formatters:
    pretty: true
    allure:
      output_path: %paths.base%/build/allure
  extensions:
    Allure\Behat\AllureFormatterExtension:
      severity_key: "severity:"
      ignored_tags: "tag_ignore"
      issue_tag_prefix: "JIRA:"
      test_id_tag_prefix: "BUG:"

Here:

  • output_path - defines the output dir for report XML data. Default is ./allure-results
  • ignored_tags - either a comma separated string or valid yaml array of Scenario tags to be ignored in reports
  • severity_key - tag with this prefix will be interpreted (if possible) to define the Scenario severity level in reports (by default it's normal).
  • issue_tag_prefix - tag with this prefix will be interpreted as Issue marker and will generate issue tracking system link for test case
  • test_id_tag_prefix - tag with this prefix will be interpreted as Test Case Id marker and will generate TMS link for test case

Use attachment support

To have attachments in allure report - make sure your behat runs tests with Mink

Allure can handle exception thrown in your Context if that exception is instance of ArtifactExceptionInterface and get screenshots path from it.

How does it work?

Behat has the following test structure:

It has Features described in separate feature files
        Each Feature contains Scenarios
            Each scenario contains Steps

Allure has a bit different hierarchy:

    Each report contains Test Suites
        A Test Suite contains Test Cases
            Every Test Case can contain one or more Steps

On the other hand, Allure also supports grouping Test Cases by Feature, by Story or by Severity level.

Behat Allure formatter does the following mapping:

  • Behat Test Run -> Allure Test Suite
  • Gherkin Scenario (and every single Example in Scenario Outline, too) -> Allure Test Case
  • Gherkin Step -> Allure Test Step

Behat Scenarios are annotated with it's feature title and description to be grouped into Allure Feature.

Behat also has tags and they are also can be used in Allure reports:

  • If a tag appears in ignored_tags configuration parameter, then it will be ignored and will not appear on Allure report
  • If a tag starts with severity_tag_prefix, then formatter will try to interpret it's affixed part as one of the possible Allure Severity Levels
  • If a tag starts with test_id_tag_prefix, then formatter will interpret it's affixed part as Test Case Id for your TMS
  • In all other cases tag will be parsed as Allure Story annotation

Contribution?

Feel free to open PR with changes but before pls make sure you pass tests ./vendor/behat/behat/bin/behat

统计信息

  • 总下载量: 176.42k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 14
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 13
  • Watchers: 4
  • Forks: 23
  • 开发语言: PHP

其他信息

  • 授权协议: Apache
  • 更新时间: 2016-12-05