- All changes to the application must be added to the changelog (
CHANGELOG.md
), excluding changes that update build tools, changes to the code that doesn't affecting the application, etc. - The code should be linted. If the code is not formatted correctly, CI will fail. Run
manage/lint.sh
to run the linter. - Don't upgrade deps without making sure that they don't break anything. Read the changelogs. Run
manage/upgrade-deps.sh
to upgrade the deps.
- Add docstrings to all significant classes and functions.
- Double quotes all the way. Single quotes may be used to avoid escaping double quotes within the string. (Single quotes was used here previously.)
- Git (Git CLI or GitHub for Windows)
- Python 3.7 w/ pip
- Docker and Docker Compose
- (Optional) VS Code
- flake8 linter extension
- (Optional) SQLite browser (e.g. DB Browser for SQLite) (for browsing the SQLite dev DB)
- (Optional) Travis Tool (for encrypting files for Travis CI)
git config --global core.autocrlf false
git config --global user.name <username>
git config --global user.email <email-address>
... or use GitHub for Windows.
Optional, used only for encrypting Travis CI secrets and files and stuff.
sudo apt install ruby-dev rubygems
sudo gem install travis
The dev server can be run in multiple ways, and each way have isolated configs and data so that they don't interfere with eachother (it's in .local
). However, most tools are only supported in the first approach, the simple Docker container.
This is the intended way to run the dev server and other tools. It consists of a Django dev server inside a Docker container. Scripts in manage
, except manage/ci
, manage/full
and manage/venv
, are used to interact with the server and other tools. Configs for it are found in setup/simple
(don't change these) and .local/simple
(change these instead). We (Casual Gaming) use our Keycloak server with realm "dev" with client "cag-events-local" for local testing.
Setting up and running the dev server:
# First time only
# If it tells you to fix the config; fix the config and run it again
manage/setup.sh
# For running migrations, not needed the first time
manage/update.sh
# Start the dev server
# Press CTRL+C to stop it
manage/run.sh
# Run unit tests and linter
manage/test.sh
manage/lint.sh
# Run a bunch of tests, do this before committing and pushing
manage/check.sh
# Delete all local files like databases, configs, etc.,
# in case you need to start over
manage/clean.sh
# Most scripts in there have comments inside regarding what they do
This setup is meant for testing the app in a more realistic scenario. It contains the app container, a database container (PostgreSQL) and a reverse proxy container (nginx).
# First time only
# If it tells you to fix the config; fix the config and run it again
manage/full/setup.sh
# No comment needed
manage/full/run.sh
It is recommended to set up Virtualenv for use by IDEs. It'll give the them access to the dependencies used and such (source code and tools).
# Create venv, install dependencies inside, etc.
manage/venv/setup-basic.sh
# Now tell your IDE to use the venv
You could use Virtualenv instead of Docker (the simple one), it probably won't even matter.
# First time only
# If it tells you to fix the config; fix the config and run it again
manage/venv/setup.sh
# Prepare for liftoff
manage/venv/run.sh