berpress/swagger-coverage

View on GitHub
swagger_coverage/scripts/swagger_report.py

Summary

Maintainability
A
0 mins
Test Coverage
#!/usr/bin/env python
import argparse
import logging.config
import sys

from swagger_coverage.src.coverage import SwaggerCoverage
from swagger_coverage.src.logger import setup

logger = logging.getLogger("swagger")

LOGGER_LEVEL = ["CRITICAL", "ERROR", "WARNING", "INFO", "DEBUG"]


def main():
    parser = argparse.ArgumentParser(description="Swagger coverage")
    parser.add_argument("url", type=str)
    parser.add_argument(
        "-s",
        "--status-codes",
        nargs="+",
        help="set status codes to " "create a report",
        type=str,
    )
    parser.add_argument(
        "-l", "--level", help=f"set logging level {LOGGER_LEVEL}", type=str
    )
    parser.add_argument("-p", "--path", help="path to report folder", type=str)
    args = parser.parse_args()
    url = args.url
    path = args.path
    status_codes = args.status_codes
    logging_level = args.level
    if logging_level is None:
        logging_level = "INFO"
    elif logging_level not in LOGGER_LEVEL:
        raise ValueError("Check logger level")
    setup(logging_level)
    logger.setLevel(logging_level)
    swagger = SwaggerCoverage(url=url, status_codes=status_codes, path=path)
    swagger.create_coverage_data()


if __name__ == "__main__":
    try:
        main()
    except ValueError:
        sys.exit(2)