A command-line tool to generate PDF for SonarQube Reports
Project description
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 meansSonarQube Community Editionand thePostgres DB. -
The configured username and password for the database can be found out in the docker compose file.
-
Please procced to navigate to
localhost:9000as 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 asadminand password asadmin. 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a786917e9449c387ce7eb90a5df937930807cf0435bb5557bc5fd371e6a1cce6
|
|
| MD5 |
47814a31c847b27e46f3e05bd12138d8
|
|
| BLAKE2b-256 |
93c86b942f7b8b907aa4ddc947ba96ff788d1c143246cf813a80385ddf40d49f
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eed828bb4942586b28c96e4248b675a4cf936dff52b9fff60a4b1f2e15473e9b
|
|
| MD5 |
ca95dc2dd05c68468e179b379d54198c
|
|
| BLAKE2b-256 |
32b9f560b0347d2f46d11f1cb12eb5d26c42dedda9e6167ee1fab737ae57696d
|