Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

behave-testrail-reporter

Package Overview
Dependencies
Maintainers
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

behave-testrail-reporter

Behave library to integrate with Testrail API

  • 0.5.1
  • PyPI
  • Socket score

Maintainers
5

Behave to TestRail Reporter

CircleCI Codacy Badge Codacy Badge pullreminders

This integration is used to add test results to TestRail automatically when Behave tests are executed.

Example of the generated report:

3 testrail test cases passed, 0 failed, 19 skipped, 2 untested
Took 0m6.349s

Install

Can install it using pipenv

$ pipenv install behave-testrail-reporter

or using pip

$ pip install behave-testrail-reporter

Setup

Add TestrailReporter to behave reporters in your /features/environment.py by adding this code in before_all()

from behave_testrail_reporter import TestrailReporter

def before_all(context):
    # ... all your other awesome code in here
    current_branch = os.environ.get('CIRCLE_BRANCH') # Change this to get the current build branch of your CI system
    testrail_reporter = TestrailReporter(current_branch)
    context.config.reporters.append(testrail_reporter)

Create a testrail.yml config file in the root of your project

Example structure:

base_url: https://your-domain.testrail.io
projects:
  - name: 'Advanced tests on branch {branch}'
    id: 123
    suite_id: 456
    # note: this will allow any branch to push test case results to Testrail.
    allowed_branch_pattern: '.*'
  - name: 'Smoke tests on branch {branch}'
    id: 1234
    suite_id: 789
    # note: this will allow any branch to push test case results to Testrail.
    allowed_branch_pattern: '.*'

Allow only master branch and release1.111.1 to push test results to Testrail:

base_url: https://your-domain.testrail.io
projects:
  - name: 'Full E2E tests on branch {branch}'
    id: 123
    suite_id: 456
    allowed_branch_pattern: '^(master|release\/\d+([\.\d]+)?)$'
yaml keyDescription
nameProject name
idTestrail project id
suite_idTestrail Suite id
allowed_branch_patternRegular expression to restrict when a test run is executed

name - You can use some project variables to create dynamic test run names

VariableExampleResult
{project_id}'Test run {project_id}'Test run 123
{suite_id}'Test run {suite_id}'Test run 456
{branch}'Test run {branch}'Test run master

Environment variables required

Variable nameDescription
TESTRAIL_KEYTestRail user password
TESTRAIL_USERTestRail user email address

How to use

To get test cases marked as success or fail on TestRail we have to add tags with TestRail test case ID on each scenario.

Test case tag structure:

prefix + test case id

@testrail- + C1104

See example below:

Feature: Log in and out

    Background:
        Given I am logged out from Hub
        And I navigate to the home page

    @testrail-C1104
    @testrail-C45933
    Scenario: Admin can login
        When I enter the username admin
        And I enter the password admin
        And I click the Login button
        Then I see the admin's landing page

Note: some scenarios can cover multiple TestRail cases, for that you just need to add multiple tags.

How to contribute

Install dependencies for development

pipenv install --dev

How to run tests

Activate your virtual environment and then just run tox.

tox

How to distribute

If you need to publish a new version of this package you can use this command:

python setup.py sdist bdist_wheel
twine upload dist/*

License

Licensed under MIT license. View license.

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc