The Kartenforum Georeference provides the georeferencing functionality for the Virtual Map Forum 2.0. This platform allows users to explore and interact with both historical and georeferenced maps. The service is designed to efficiently manage and process georeferenced map data. Using FastAPI, it delivers a scalable and high-performance API, while PostgreSQL (and PostGIS) manages spatial data storage and queries.
- Get Started
- Configuration
- Linting and Formatting
- Running Tests
- PostgreSQL Database
- Testing with Postgres and Testcontainers
- Debugging
- License
-
Set environment variables for the docker build: There are two environment variables required for the docker build,
USERNAME
andUID
export USER=$(whoami) export UID=$(id -u)
Also see this script https://github.com/pikobytes/slub_ddev_kartenforum/blob/main/generate-env.sh for more information.
-
Start Docker containers:
cd docker/ docker-compose up
-
In your IDE make sure to use the correct python interpreter. The one in the
.venv
folder, which should have been automatically added by the docker container. -
The server should be available under
http://localhost:8000/
-
Set up a virtual environment and install poetry.
python3 -m venv .venv .venv/bin/pip install poetry==1.8.3
-
Install the required dependencies
.venv/bin/poetry install
In case you experience any issues with python-gdal, make sure the version matches your local gdal version. Also if you make any changes to
pyproject.toml
. Also, if you make any changes topyproject.toml
you need to run.venv/bin/poetry lock
again. -
Set Up the pre-commit hooks
.venv/bin/poetry run pre-commit install
-
Run the server:
uvicorn georeference.main:app --reload
Configuration is managed via environment variables. They can be set in the following ways:
- Directly in the environment: These take precedence over everything else.
- In a
.env.production
file in the root of the project: This file will be automatically loaded bypydantic-settings
and will take precedence over the default values defined in.env
. It does not need to be exhaustive, only the variables that should be overwritten are required. - In a
.env
file: This file is also automatically loaded bypydantic-settings
.
For more information, check the Pydantic documentation.
This project utilizes ruff for both linting and code formatting, with the configuration
specified in the pyproject.toml
file. To maintain consistency, please ensure that your IDE is configured to use Ruff for code formatting. Additionally,
linting and formatting tasks are automatically enforced as pre-commit hooks to help uphold code quality.
If you want to run all tests make sure to have ddev-kartenforum locally setup and running.
-
Please install the following dependencies and download and initialize the test data:
sudo apt install libvips libvips-tools sshpass libvips-tools scripts/initialize-testdata.sh
-
Run all tests:
.venv/bin/poetry run pytest
-
To run specific tests, use the following command structure:
.venv/bin/poetry run pytest -rP georeference/tests/utils/proj_test.py::test_get_crs_from_request_params_use_passed_crs
💡 Tips:
- Ensure Docker is running, as the
testcontainers
library will spin up a PostgreSQL container for the tests. - Make sure
DEV_MODE
is enabled to avoid SSL verification failures when querying the TYPO3 application. - Properly set up your local environment for testing.
docker can be used to set up a development infrastructure
cd docker/
docker-compose up
To modify the database schema, use the alembic library for versioned migrations. The database connection URL is managed
in the settings.py file, which reads from the .env
.
To create a new migration, run the following command:
poetry run alembic revision -m "your message"
This will generate a new migration file in the alembic/versions
folder.
If the versions folder does not exist inside the alembic directory, please create it manually:
sudo mkdir alembic/versions
After making your changes, apply the migration using the command:
poetry run alembic upgrade head
This updates the database schema to the latest version. For more information also check the alembic documentation.
The project uses postgres-test-container library.
-
Container Setup:
For each test, a temporary Docker container is created, running a PostgreSQL database calledvkdb
. The necessary database schema is automatically set up when the container is initialized. -
Data Initialization:
Before running each test, we make sure to clear any existing datas in tables and relationships in the database. Then, we populate these tables with initial data to ensure a consistent starting point for testing. -
Data Cleanup:
After each test, we clean up the data in the tables to maintain a clean slate for the next test. -
Automatic Cleanup:
Once all tests are completed, the Docker container is automatically stopped and deleted to keep your environment tidy.
To facilitate debugging, you can run the application directly through your IDE’s debugger, allowing you to set breakpoints, inspect variables, and step through the code.
-
Open the Run/Debug Configurations:
In the top-right corner of PyCharm, click on the dropdown next to the run button and select Edit Configurations. -
Add a New Configuration:
Create a new configuration for FastAPI or Pytest:- For test debugging, select the Pytest option and specify the test files or directories you wish to debug.
-
Start Debugging:
Once set up, you can start the server or run tests in debug mode. The debugger will pause at any breakpoints you've set, allowing for detailed inspection of the execution flow.
💡Tip:
If you encounter issues with relative paths, try using the absolute path to the files in the configuration.
This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details.