Pytest plugin for sending report to testrail system.
Project description
Pytest Testrail Integrator.
Pytest-testrail-integrator is a pytest extension for reporting test results to Testrail.
Pytest-testrail-integrator gives an ability to send test results to specific testrail run or can create new one during
test execution. Fully compatible with xdist
parallelization tool.
Installation
pip install pytest-testrail-integrator
Example
In order to link pytest test to testrail case you need to mark test with pytest.mark.case
or tr_case
decorator with testcase id passing as argument.
import pytest
from pytest_testrail_integrator.client import tr_case
@pytest.mark.case('98765') # Use raw pytest marker.
def test_sum():
assert 1 + 1 == 2
@tr_case('987654') # Use custom decorator.
def test_divide():
assert 2 / 1 == 2
Test case id must not start with "C" char and can be either string or integer.
Main flow overview.
At startup plugin checks if the Testrail run id is passed or not. If not passed - plugin will create new test run by itself. Then during tests execution testrail tests will be updated in real time.
Config for TestRail
- All required configs can be loaded from virtual environment variables(higher priority) :
TR_RUN_ID
TR_API_URL
TR_USER_EMAIL
TR_USER_PASSWORD
TR_PROJECT_ID
TR_SUTE_ID
Or
- Add options to
pytest.ini
file.
Launch
In order to start tests with Pytest-Message you must provide --tr-reporting
flag:
pytest tests --tr-reporting
All available command line options.
option | description |
---|---|
--tr-reporting | Create and update testruns with TestRail |
--tr-deselect-tests | If pass testrun id only. Selects only tests which have been marked with case decorator with appropriate case id. Other tests are marked as deselected and not started in test execution. |
All available pytest.ini options.
option | description |
---|---|
tr_api_url | Testrail api url. |
tr_run_id | Testrail test run id. If passed test reports are linked to this particular test run. |
tr_user_email | Testrail User email for API authentication. |
tr_user_password | Testrail User password for API authentication. |
tr_project_id | Testrail Project Id. Required for new test run creation if Test Run Id is not passed. |
tr_suite_id | Testrail Suite Id. Required for new test run creation if Test Run Id is not passed. |
tr_tb | Traceback level in testrail message reports. ['short', 'long'] options. Short is selected by default. |
Hooks
pytest_tr_generate_run_name(config: pytest.Config) - > str:
Executes for generating new testrail run name right before create test run request is sent. Takes first hook result.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pytest-testrail-integrator-0.0.7.tar.gz
.
File metadata
- Download URL: pytest-testrail-integrator-0.0.7.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e906b9c063bf0ec512b957ff8ac46883ea9242daa72cd0aa559e5a38da103003 |
|
MD5 | 099b90df02a7d5265d919b8f6cb5ee79 |
|
BLAKE2b-256 | a87658a73066d734ade15b865342000f060e7d6aeca51708ede52d5d6c5f64cd |
File details
Details for the file pytest_testrail_integrator-0.0.7-py3-none-any.whl
.
File metadata
- Download URL: pytest_testrail_integrator-0.0.7-py3-none-any.whl
- Upload date:
- Size: 11.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 62ba0b60022eaaa02924d99aee419a99a1dff7fedb588e532e76f795d3a49b29 |
|
MD5 | 25ab23a2a960fffe4dcac11bc31f8ab6 |
|
BLAKE2b-256 | b77137c5b0cbc8415e288286e246afc00cf0d60f96e4fe1ffa233b2f06a7eaf2 |