Skip to content

All things to do with the datamodel and its storage. Including alembic migrations and datamodel code.

License

Notifications You must be signed in to change notification settings

climatepolicyradar/navigator-db-client

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NAVIGATOR DB CLIENT

All things to do with the data model and its storage. Including alembic migrations and data model code.

Used by

Setting up the repository

To install and run the pre-commit hooks (which run using Trunk.io), please run make install_trunk. This will install and initialise Trunk if it does not already exist in your PATH. Then, run make git_hooks to run Trunk's built-in linting trunk check and formatting trunk fmt tools.

Read more about Trunk via their docs page here.

How to use as dependency

  1. Include the following in the pyproject.toml:
db-client = {git = "https://github.com/climatepolicyradar/navigator-db-client.git", tag = {LATEST_TAG}}
  1. Run poetry lock

Run migrations

Migrations run automatically at the beginning of the backend service executions using the db_client.run_migrations function.

Make migrations

# First start postgres
# Ensure you drop and recreate navigator db, so its empty
alembic upgrade head
alembic revision --autogenerate -m "migration message"

Test

DB for test is mocked using pytest_mock_resources

make test

TODO

  • Create more unit testing here
  • Automatic documentation for pipeline

About

All things to do with the datamodel and its storage. Including alembic migrations and datamodel code.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages