A pytest plugin for creating incremental XML test reports for Testhide system.
Project description
Testhide Pytest Plugin
A professional-grade pytest plugin that generates robust JUnit-style XML reports. This plugin was designed to solve real-world CI/CD challenges by ensuring data integrity during test failures and providing full support for parallel test execution.
Key Features
- Incremental Reporting: Every single test result is saved immediately, guaranteeing that partial results are available even if a test run is catastrophically interrupted.
- Full
pytest-xdistCompatibility: The plugin uses a robust temporary file and merge strategy, enabling it to work flawlessly with parallel test execution (-n X). pytest-rerunfailuresSupport: Every rerun of a failing test is logged as a separate<testcase>in the final report, providing a complete and accurate picture of flaky tests.- JIRA Integration: Automatically enriches failure reports with information from JIRA, linking test failures to known bugs and their statuses.
- Clean Stack Traces: Automatically removes internal "noise" from pytest and pluggy calls in stack traces, leaving only the relevant information from your application and test code.
- Atomic & Safe Writes: Uses a temporary directory and a final, atomic merge to ensure the report file is never corrupted, even under heavy load or across multiple concurrent builds on the same agent.
Installation
pip install testhide-pytest-plugin
Usage
Basic Run
To activate the plugin and generate a report, use the --report-xml option:
pytest --report-xml=junittests.xml
Parallel Execution (pytest-xdist)
The plugin is fully compatible with pytest-xdist out of the box. Simply add the -n flag to run tests in multiple processes. The plugin will automatically handle and merge the results from all worker nodes.
pytest -n auto --report-xml=junittests.xml
Rerunning Failed Tests (pytest-rerunfailures)
The plugin works seamlessly with pytest-rerunfailures. Every attempt of a failing test will be recorded in the final report, allowing for accurate tracking of test instability.
pytest --reruns 5 --report-xml=junittests.xml
JIRA Integration
The plugin can automatically enrich failure reports with information from JIRA, linking test failures to known bugs and their statuses. There are two ways to configure this integration.
Method 1: Command-Line Arguments
You can enable JIRA integration by providing the connection details as command-line options. The integration is activated automatically when all three parameters are present.
- --jira-url: The URL of your JIRA instance.
- --jira-username: The username for the connection.
- --jira-password: The password or API token for the user.
pytest --report-xml=junittests.xml \
--jira-url="[https://jira.yourcompany.com](https://jira.yourcompany.com)" \
--jira-username="my-bot" \
--jira-password="your-api-token"
Method 2: Programmatic Configuration (for Frameworks)
If you are developing a test framework plugin and manage credentials in a central configuration object (e.g., a YAML file), you can programmatically set the JIRA options. This avoids exposing credentials in CI scripts.
Use the pytest_cmdline_main hook in your own plugin to set the configuration options before the testhide-plugin is configured.
import pytest
class MyFrameworkPlugin:
@pytest.hookimpl(tryfirst=True)
def pytest_cmdline_main(self, config):
# Assuming ConfigApp loads your central configuration
# from a file or environment variables.
from my_framework.config import ConfigApp
config.option.jira_url = ConfigApp.jira.url
config.option.jira_username = ConfigApp.jira.username
config.option.jira_password = ConfigApp.jira.password
Extending the Plugin (For Framework Developers)
testhide-pytest-plugin provides custom hooks for integration with your own plugins, allowing you to inject project-specific metadata into the report.
Example implementation in your plugin:
pytest_testhide_add_metadata(plugin)
This hook allows you to add metadata at the session level (e.g., build information, branch name, etc.). It must return a list of (name, value) tuples.
from pytest import hookimpl
class MyFrameworkPlugin:
@hookimpl
def pytest_testhide_add_metadata(self, plugin):
return [
('build', '1.2.3'),
('branch', 'develop')
]
pytest_testhide_get_test_case_properties(item, report)
This hook allows you to add data at the individual test case level (e.g., a docstring, steps to reproduce, or artifact links). It must return a list of (name, value) tuples.
from pytest import hookimpl
class MyFrameworkPlugin:
@hookimpl
def pytest_testhide_get_test_case_properties(self, item, report):
properties = []
if item.obj and item.obj.__doc__:
properties.append(('docstr', item.obj.__doc__.strip()))
# Example of adding an artifact link
if hasattr(item, 'artifact_url'):
properties.append(('attachment', item.artifact_url))
return properties
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file testhide_pytest_plugin-0.2.2.tar.gz.
File metadata
- Download URL: testhide_pytest_plugin-0.2.2.tar.gz
- Upload date:
- Size: 11.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6737e12fd2f700dea337777fd4df41a0f5ad069125c46d3ae6b1ef1871c9b470
|
|
| MD5 |
0239b3cd604a8abbcbbc22254826fdde
|
|
| BLAKE2b-256 |
b7babe7bdd6a7460835bb4f660544a6b8efbede223f8ee19cc27e130cf75baab
|
File details
Details for the file testhide_pytest_plugin-0.2.2-py3-none-any.whl.
File metadata
- Download URL: testhide_pytest_plugin-0.2.2-py3-none-any.whl
- Upload date:
- Size: 10.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29e68207bb859e845af02e1801435630de3b16d8ffdb0d57bbfa468cc3840b2e
|
|
| MD5 |
8a1d8c91338bd95dd6155ccb27591fe6
|
|
| BLAKE2b-256 |
3b44b90327eb0e78bb39f8168ebdf949bf6e61b30a3683f5c5ef434ce725ebb9
|