Skip to content

JamalZeynalov/swagger-coverage-py

Repository files navigation

Supported Python Versions Version

swagger-coverage-py

This project is the adapter that allows using swagger-coverage tool in Python projects (PyTest+Requests).

Original description summary:

Swagger-coverage gives a full picture about coverage of API tests (regression) based on OAS 2 (Swagger). By saying coverage we mean not a broad theme functionality, but presence (or absence) of calls defined by API methods, parameters, return codes or other conditions which corresponds specification of API.

Some more info about the project you can also find HERE

How to use:

All required steps are listed below. Additionally, you can find a working example here: allure-results-sample.

0. Resolve dependencies:

  • python 3.6+
  • java JDK 11+ (with JAVA_HOME environment variable set)
  • Enable Long Paths (Windows only). Check the guide HERE

1. Install swagger-coverage-py as a project requirement.

pip install swagger-coverage

2. Add environment variables (Optionally):

API_DOCS_TYPE="swagger"  # Note: "openapi" is default type of API docs
API_DOCS_VERSION="2.0"  # Note: "3.0.0" is default version of API docs
API_DOCS_FORMAT="yaml"  # Note: "json" is default format of API docs and output files
API_COVERAGE_REPORTS_DISABLED=True  # Skip requests recording. No files will be saved to 'swagger-coverage-output' dir 
DEBUG_MODE=True  # Enable debug mode. All commandline logs will be printed to console (False by default)

3. Add the session-scoped fixture

import pytest
from swagger_coverage_py.reporter import CoverageReporter
from requests.auth import HTTPBasicAuth


@pytest.fixture(scope="session", autouse=True)
def setup_swagger_coverage():
    reporter = CoverageReporter(api_name="my-project", host="http://my-project.com")
    reporter.cleanup_input_files()
    reporter.setup("/api/v1/resources/my_project/doc/swagger.json", auth=HTTPBasicAuth("username", "password"))

    yield
    reporter.generate_report()

If you have 2 and more projects, then just add more reporters:

import pytest
from swagger_coverage_py.reporter import CoverageReporter
from requests.auth import HTTPBasicAuth


@pytest.fixture(scope="session", autouse=True)
def setup_swagger_coverage():
    reporter = CoverageReporter(api_name="petstore", host="https://petstore.swagger.io")
    reporter.cleanup_input_files()
    reporter.setup(path_to_swagger_json="/v2/swagger.json")

    reporter2 = CoverageReporter(api_name="my-project", host="http://my-project.com")
    reporter2.cleanup_input_files()
    reporter2.setup(path_to_swagger_json="/api/v1/swagger.json", auth=HTTPBasicAuth("username", "password"))

    yield
    reporter.generate_report()
    reporter2.generate_report()

YAML format is also supported:

import pytest
from swagger_coverage_py.reporter import CoverageReporter


@pytest.fixture(scope="session", autouse=True)
def setup_swagger_coverage():
    reporter = CoverageReporter(api_name="petstore", host="https://petstore.swagger.io")
    reporter.cleanup_input_files()
    reporter.setup("/v2/swagger.yaml")

    yield
    reporter.generate_report()

Steps and Parameters:

api_name - Define the name of the API. This name will be used to find a configuration file.
     For APIs in this example the files must have names swagger-coverage-config-petstore.json and swagger-coverage-config-my-project.json.

host - The host of the API. It will be used to download a swagger.json file and to identify the CoverageListener output directory for each API.

cleanup_input_files() - THis step deletes all files in the CoverageListener output directory (according to the target host)

path_to_swagger_json - A second part of the HTTP link to your OpenApi/Swagger documentation in JSON format
     Adapted swagger-<api_name>.json file will be created in your project root.
     The "Swagger 2.0" format is completely compatible with this tool.
     The "OpenAPI 3.0.2" format is partly compatible. "Tags coverage summary" calculation is not supported.

auth - An authentication parameter for "requests" lib. Skip it if your API doesn't require authentication.

4. Create and place swagger-coverage-config-<api_name>.json file(s) to your project:

{
    "rules": {
        "status": {
            "enable": true,
            "ignore": [
                "500"
            ],
            "filter": []
        },
        "paths": {
            "enable": true,
            "ignore": [
                "/user/{username}"
            ]
        },
        "only-declared-status": {
            "enable": false
        },
        "exclude-deprecated": {
            "enable": true
        }
    },
    "writers": {
        "html": {
            "locale": "en",
            "filename": "swagger-coverage-report-petstore.html"
        }
    }
}

The path section is designed to exclude specific endpoints (all methods) from the final HTML report. To do this, you need to set enable parameter to true and specify a list of endpoints (as you see them in the swagger doc) in the ignore section. Then these endpoints will be removed from the API doc before it is saved locally.
Note: Remove already downloaded API docs before running a new version of this lib.

If you have more than 1 API then this config MUST:

1. Be created for each microservice which you track using CoverageListener.

Otherwise, the default behavior will be applied, and your report will be saved as swagger-coverage-report.html which may cause override in case you have multiple APIs

2. Contain writers section with filename in the format: swagger-coverage-report-<api_name>.html

3. Be placed in the root of your project