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
.
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
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]'
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]'
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
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.
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).
| Name | E-mail | Role | |------|------------|--------|-----------------| | Carlos Madariaga | carlos.madariaga@bam.de | Admin | | Dr. Jose M. Pizarro | jose.pizarro-blanco@bam.de | Maintainer | | Jörg Rädler | joerg.raedler@bam.de | Maintainer | | Dr. Angela Ariza | angela.ariza@bam.de | Maintainer |