Skip to content

Latest commit

 

History

History
74 lines (47 loc) · 1.91 KB

README.md

File metadata and controls

74 lines (47 loc) · 1.91 KB

arq-sqlalchemy-boilerplate

build

Boilerplate for services with Arq, SQLAlchemy, Docker, Alembic and Pytest.

Why

Here is modern and fully asynchronous way to run scheduled or triggered tasks in python. This boilerplate will fit any integration purpose when you need to synchronize resources or databases.

Current project is pytest friendly. It is very easy to start writing tests for your code here.

How to start

Copy whole project and remove or rewrite all dummy code with example in it. There is an example migration file in migrations/versions/ directory, so you may want to remove it also.

To set up your environment locally you need to define SQLALCHEMY_DATABASE_URI and ARQ_BACKEND parameters in .env file. Check .env.example as an example.

Dependencies

Install pipenv

pip install pipenv

Then run

pipenv install

Code your project

Create arq tasks (they are just coroutines) in src/app/tasks.py files. Register tasks in workers src/app/arq.py.

Arq docs: https://arq-docs.helpmanual.io/

Tests

There are ready-to-use database fixtures which can greatly help with testing your code in near to production way. Don't forget to run your database, e.g. with docker-compose up -d command.

To run tests:

cd src && pytest

Code style and linters

Run all-in-one command:

isort . && black . && flake8

Migrations

This boilerplate uses Alembic to run and create new migrations.

To auto-generate migrations:

alembic revision --autogenerate -m "Some migration name"

To run migration (with database on):

cd src && alembic upgrade head

To run migration in prod compose:

docker-compose -f docker-compose.prod.yml run arq alembic upgrade head