Pytest plugin for reporting test results of the Pytest to the ReportPortal.
DISCLAIMER: We use Google Analytics for sending anonymous usage information such as agent's and client's names, and their versions after a successful launch start. This information might help us to improve both ReportPortal backend and client sides. It is used by the ReportPortal team only and is not supposed for sharing with 3rd parties.
To install pytest plugin execute next command in a terminal:
pip install pytest-reportportalLook through the CONTRIBUTING.rst for contribution guidelines.
Prepare the config file pytest.ini in root directory of tests or specify any one using pytest command line option:
py.test -c config.cfgThe pytest.ini file should have next mandatory fields:
rp_project- name of project in ReportPortalrp_endpoint- address of ReportPortal Server
And one type of authorization: API Key or OAuth 2.0 Password grant. You can do this by setting:
rp_api_keyorRP_API_KEYenvironment variable. You can get it in the User Profile section on the UI.
Or:
rp_oauth_uri- OAuth 2.0 token endpoint URL for password grant authentication. Required if API key is not used.rp_oauth_username- OAuth 2.0 username for password grant authentication. Required if OAuth 2.0 is used.rp_oauth_password- OAuth 2.0 password for password grant authentication. Required if OAuth 2.0 is used.rp_oauth_client_id- OAuth 2.0 client identifier. Required if OAuth 2.0 is used.rp_oauth_client_secret- OAuth 2.0 client secret. Optional for OAuth 2.0 authentication.rp_oauth_scope- OAuth 2.0 access token scope. Optional for OAuth 2.0 authentication.
Example of pytest.ini:
[pytest]
rp_api_key = fb586627-32be-47dd-93c1-678873458a5f
rp_endpoint = http://192.168.1.10:8080
rp_project = user_personal
rp_launch = AnyLaunchName
rp_launch_attributes = 'PyTest' 'Smoke'
rp_launch_description = 'Smoke test'
rp_ignore_attributes = 'xfail' 'usefixture'
There are also optional parameters: https://reportportal.io/docs/log-data-in-reportportal/test-framework-integration/Python/pytest/
For logging of the test item flow to ReportPortal, please, use the python logging handler provided by plugin like below:
in conftest.py:
import logging
import pytest
from reportportal_client import RPLogger
@pytest.fixture(scope="session")
def rp_logger():
logger = logging.getLogger(__name__)
logger.setLevel(logging.DEBUG)
logging.setLoggerClass(RPLogger)
return loggerin tests:
# In this case only INFO messages will be sent to the ReportPortal.
def test_one(rp_logger):
rp_logger.info("Case1. Step1")
x = "this"
rp_logger.info("x is: %s", x)
assert 'h' in x
# Message with an attachment.
import subprocess
free_memory = subprocess.check_output("free -h".split())
rp_logger.info(
"Case1. Memory consumption",
attachment={
"name": "free_memory.txt",
"data": free_memory,
"mime": "application/octet-stream",
},
)
# This debug message will not be sent to the ReportPortal.
rp_logger.debug("Case1. Debug message")To run test with ReportPortal you must provide --reportportal flag:
py.test ./tests --reportportalCheck the documentation to find more detailed information about how to integrate pytest with ReportPortal using the agent: https://reportportal.io/docs/log-data-in-reportportal/test-framework-integration/Python/pytest/
Licensed under the Apache 2.0 license (see the LICENSE file).