Skip to main content

Agent for Reporting results of tests to the Report Portal

Project description

ReportPortal integration for pytest framework

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.

PyPI Python versions Tests codecov Join Slack chat! stackoverflow Build with Love

Installation

To install pytest plugin execute next command in a terminal:

pip install pytest-reportportal

Look through the CONTRIBUTING.rst for contribution guidelines.

Configuration

Prepare the config file pytest.ini in root directory of tests or specify any one using pytest command line option:

py.test -c config.cfg

The pytest.ini file should have next mandatory fields:

  • rp_project - name of project in ReportPortal
  • rp_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_key or RP_API_KEY environment 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/

Examples

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 logger

in 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")

Launching

To run test with ReportPortal you must provide --reportportal flag:

py.test ./tests --reportportal

Check 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/

Copyright Notice

Licensed under the Apache 2.0 license (see the LICENSE file).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytest_reportportal-5.6.8.tar.gz (33.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pytest_reportportal-5.6.8-py2.py3-none-any.whl (32.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pytest_reportportal-5.6.8.tar.gz.

File metadata

  • Download URL: pytest_reportportal-5.6.8.tar.gz
  • Upload date:
  • Size: 33.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pytest_reportportal-5.6.8.tar.gz
Algorithm Hash digest
SHA256 17d77180b161e833f0fdf7cdd10558b2f01ea7f68dedda8e4ee65a4e5b6fe41d
MD5 4ff334085687b1594cfbe5323d2d0b11
BLAKE2b-256 68594ffa0801f828ca5f0fa6d68cf311baf13c49e2b58908dd62ec13ef9bf6ef

See more details on using hashes here.

File details

Details for the file pytest_reportportal-5.6.8-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_reportportal-5.6.8-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2ed21ed32f41829b92d16eaacbe072bf1b0b926006a9b359a61d9e72d8af9708
MD5 8da3596e07f4c0fe1860a9f04d8c7bb9
BLAKE2b-256 dd028c393b829e0a01990a9c91003b8cbb90b1cb34d7ad0c2da4aa28cef9acf4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page