Skip to main content

A command-line tool to generate PDF for SonarQube Reports

Project description

PyPI Downloads Made with love in Japan Python

RedCoffee

RedCoffee is a command-line tool designed to manage SonarQube reports easily. It allows you to generate PDF reports from SonarQube analysis data. The project mainly targets SonarQube Community Edition since it lacks the default capability to export PDF reports.

Installation

To install RedCoffee, you can use pip. First, ensure you have Python and pip installed on your system. Then, you can install RedCoffee directly from PyPI using the following command:

pip install redcoffee

Pre Requisites

The SonarQube analysis for the project should already have been completed.

Project Structure

Directory Usage
.github/workflows Github Action Files.
i) trigger-test.yaml - To Trigger Unit Tests on every commit.
ii) deploy-mkdocs.yaml - To trigger deployment of mkdocs when something is merged to main / master branch.
integrations Contains 3rd Party Integrations
i) IPInfo - To get the user's GeoLocation Details
ii) Sentry - For error analysis and logs
core The brain of the repository. The control will ultimately land up here.
i) utils - Core Utils. Utilities essential for the core functionality to be up and running.
ii) analyser.py - Most of the SonarQube API Calls being made in this file.
reports Controls the stuff related to look and feel of the generated reports.
i)templating.py - Code containing the structure of the report.
ii) utils - Code / Utility functions essential for the report templating to be up and running.
utils General Utility Functions.
tests Contains the Unit Tests.
Files Usage
redcoffee.py The entrypoint of the project
requirements.txt Includes all necessary libraries required to keep this project up and running
docker-compse.yml Brining up the docker containers if someones wants to test out things locally
wiremock-using-docker.sh Required for Trigger the unit test cases

Local Setup

Please note that the project has not been dockerised yet. Hence, it does not contain a DockerFile. However, please ensure that you have Docker installed on your system as we will require the same to have few containers up and running.

To setup RedCoffee locally on your machine, please follow the below steps

  • In your terminal, please run the following command : pip install -r requirements.txt. This will ensure all the libraries are installed in your system which is essential for the project to be up and running.

  • Next, please proceed to run the following docker command : docker compose -f docker-compose.yml up. This will ensure you have the required Infra up and running for the project to work successfully. Required Infra over here means SonarQube Community Edition and the Postgres DB.

  • The configured username and password for the database can be found out in the docker compose file.

  • Please procced to navigate to localhost:9000 as this is the address where your SonarQube instance is up and running ( unless you have changed the ports ) . It will ask you for the login. Please enter the username as admin and password as admin. It will prompt you to re-enter a new password. Please set up a password of your choice.

  • Please click on your profile icon ( right most corner ) and click on the Account Section. Navigate to the Security section. Please procced to generate a SonarQube User Token. Please remember to save this token somewhere as you won't be able to see it later.

Please note that due to the unavailability of IPInfo Access Key and Sentry DSN URL on your local system, the calls for these APIs will fail. However, this does not block the execution.

Usage

Please run the following command to generate the PDF Report

redcoffee generatepdf --host=${YOUR_SONARQUBE_HOST_NAME} --project=${SONARQUBE_PROJECT_KEY} --path=${PATH WHERE PDF FILE IS TO BE STORED} --token=${SONARQUBE_USER_TOKEN}

Documentation ( made available via Github Pages )

Please visit the Github Page for this project to stay updated with the latest changes - Github Page Documentation for RedCoffee

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

redcoffee-2.14.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

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

redcoffee-2.14-py3-none-any.whl (18.0 kB view details)

Uploaded Python 3

File details

Details for the file redcoffee-2.14.tar.gz.

File metadata

  • Download URL: redcoffee-2.14.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for redcoffee-2.14.tar.gz
Algorithm Hash digest
SHA256 a786917e9449c387ce7eb90a5df937930807cf0435bb5557bc5fd371e6a1cce6
MD5 47814a31c847b27e46f3e05bd12138d8
BLAKE2b-256 93c86b942f7b8b907aa4ddc947ba96ff788d1c143246cf813a80385ddf40d49f

See more details on using hashes here.

File details

Details for the file redcoffee-2.14-py3-none-any.whl.

File metadata

  • Download URL: redcoffee-2.14-py3-none-any.whl
  • Upload date:
  • Size: 18.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for redcoffee-2.14-py3-none-any.whl
Algorithm Hash digest
SHA256 eed828bb4942586b28c96e4248b675a4cf936dff52b9fff60a4b1f2e15473e9b
MD5 ca95dc2dd05c68468e179b379d54198c
BLAKE2b-256 32b9f560b0347d2f46d11f1cb12eb5d26c42dedda9e6167ee1fab737ae57696d

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