Go to file
Stijn De Clercq 18689c3de8 Add DB script to insert BSC and MSC 2023-06-23 19:01:54 +02:00
.github Update CI & fix broken test 2023-01-11 23:37:39 +01:00
alembic Start working on events 2023-02-16 23:44:26 +01:00
database Add DB script to insert BSC and MSC 2023-06-23 19:01:54 +02:00
didier Small bugfix in timezone printing 2023-02-17 01:04:24 +01:00
files/dictionaries
profile_pictures
tests Update CI & fix broken test 2023-01-11 23:37:39 +01:00
.editorconfig
.flake8
.gitignore
.pre-commit-config.yaml Fix pre-commit hooks 2023-02-16 23:35:50 +01:00
.python-version
alembic.ini
codecov.yaml
docker-compose.test.yml
docker-compose.yml
main.py
pyproject.toml
readme.md
requirements-dev.txt Fix pre-commit hooks 2023-02-16 23:35:50 +01:00
requirements.txt
run_db_scripts.py
settings.py Tidy up events a bit 2023-02-17 00:35:40 +01:00

readme.md

Didier

wakatime

You bet. The time has come.

Development

Didier uses Python 3.9.5, as specified in the .python-version-file. This file will cause pyenv to automatically use the correct version when you're working on Didier.

# Installing Python 3.9.5 through pyenv
pyenv install 3.9.5

# Creating a Virtual Environment and activate it
# PyCharm will automatically activate your venv
python3 -m venv venv
source venv/bin/activate

# Installing dependencies + development dependencies
pip3 install -r requirements.txt -r requirements-dev.txt

# Installing pre-commit hooks
pre-commit install

The database can be managed easily using Docker Compose. If you want to, however, you can run a regular PostgreSQL server and connect to that instead.

A separate database is used in the tests, as it would obviously not be ideal when tests randomly wipe your database.

# Starting the database
docker compose up -d

# Starting the database used in tests
docker compose -f docker-compose.test.yml up -d

Commands

All of these are Python tools. Depending on your OS and configuration, you may have to prefix them with python3 -m.

# Starting Didier
python3 main.py

# Running database migrations
alembic upgrade head

# Creating a new database migration
alembic revision --autogenerate -m "Revision message here"

# Running tests
pytest

# Running tests with Coverage
coverage run -m pytest
# Generating code coverage report
coverage html

# Running code quality checks
black
flake8
mypy

It's also convenient to have code-formatting happen automatically on-save. The Black documentation explains how to set this up for different types of editors.