Skip to content

Latest commit

 

History

History
152 lines (117 loc) · 4.69 KB

README.md

File metadata and controls

152 lines (117 loc) · 4.69 KB

BAM Data Store: MasterDataChecker

The masterdata_checker is a Python package used to check the correctness of a given Masterdata definitions file with respect to the entities already registered in the BAM Data Store. The package provides a Graphical User Interface (GUI) on which the user can:

  • Choose a local Masterdata file to be checked.
  • Revise the errors logs to correct mistakes in the original Masterdata file.
  • Depending on the credentials access, select a specific BAM Data Store instance and the Masterdata definitions therein.

We also provide a Jupyter Notebook as a tutorial to execute the API of masterdata_checker.

Development

If you want to develop locally this package, clone the project and enter in the workspace folder:

git clone https://git.bam.de/bam-data-store/development/masterdata_checker.git
cd masterdata_checker

Note you need to have installed the Python interface for the Tcl/Tk GUI toolkit (tkinter). If you don't have it, you can run:

sudo apt-get install python3-tk

Option 1: Virtual environment with venv

Create a virtual environment (you can use Python>3.9) in your workspace:

python3 -m venv .venv
source .venv/bin/activate

Make sure pip is upgraded:

pip install --upgrade pip

Install the package with the desired optional dependencies (specified in between brackets, e.g., [dev] or [jupy]) and in editable mode (with the added -e flag):

pip install -e '.[dev,jupy,docu]'

Option 2: uv virtual environment

We recommend using uv for fast pip installation of the package. In this case, you can instead create a virtual environment by doing:

uv venv
source .venv/bin/activate

Install the package with the desired optional dependencies (specified in between brackets, e.g., [dev] or [jupy]) and in editable mode (with the added -e flag):

uv pip install -e '.[dev,jupy,docu]'

Run the tests

You can locally run the tests by doing:

python -m pytest -sv tests

where the -s and -v options toggle the output verbosity.

You can also generate a local coverage report:

python -m pytest --cov=src tests

Run auto-formatting and linting

We use Ruff for formatting and linting the code following the rules specified in the pyproject.toml. You can run locally:

ruff check .

This will produce an output with the specific issues found. In order to auto-fix them, run:

ruff format . --check

If some issues are not possible to fix automatically, you will need to visit the file and fix them by hand.

Documentation on Github pages

To view the documentation locally, install the extra packages using:

uv pip install -e '[docu]'

The first time, build the server:

mkdocs build

Run the documentation server:

mkdocs serve

The output looks like:

INFO    -  Building documentation...
INFO    -  Cleaning site directory
INFO    -  [14:07:47] Watching paths for changes: 'docs', 'mkdocs.yml'
INFO    -  [14:07:47] Serving on http://127.0.0.1:8000/

Simply click on http://127.0.0.1:8000/. The changes in the md files of the documentation are inmediately reflected when the files are saved (the local web will automatically refresh).

Main contributors

| Name | E-mail | Role | |------|------------|--------|-----------------| | Carlos Madariaga | [email protected] | Admin | | Dr. Jose M. Pizarro | [email protected] | Maintainer | | Jörg Rädler | [email protected] | Maintainer | | Dr. Angela Ariza | [email protected] | Maintainer |