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.15.tar.gz (17.2 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.15-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for redcoffee-2.15.tar.gz
Algorithm Hash digest
SHA256 b5f3df69f9d32f4736f285c4c59ed42a3c55e51fe6697576d00ff6208908190b
MD5 0f0cde20198046cd2b5cd734e0355b93
BLAKE2b-256 416494c4de69044136d6da7ebd82a13362a243fac451fb53386a250f769ab8ef

See more details on using hashes here.

File details

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

File metadata

  • Download URL: redcoffee-2.15-py3-none-any.whl
  • Upload date:
  • Size: 18.1 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.15-py3-none-any.whl
Algorithm Hash digest
SHA256 774f9d44d6636f53218d2e58692401eed4681f05e5a39304b9a79cbbe4978f97
MD5 e400afb805a177634a0d6acc7b5ba84b
BLAKE2b-256 718902a1d08dd680f7f730eac544fac78f4132d4c6e58836ce40992ecf35025b

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