Skip to main content

A simple migrations system for asyncpg

Project description

asyncpg-trek: simple migrations for asyncpg

A simple library for managing migrations.

Target audience

Me. But maybe if you use [asyncpg] and prefer to write migrations as raw SQL (i.e. you're not using SQLAlchemy/Alembic) then you as well.

Features

  • async: migrations usually don't benefit from being async, but you benefit from using the same database driver in as your application uses (only [asyncpg] is supported).
  • simple: you just create .sql or Python files in a folder of your choosing and point this tool at that folder. No need to fight a new API to write migrations in.
  • API centric: there is no CLI to figure out, you decide how migrations get called, you control how the database connection gets created. This makes it trivial to run migrations in tests, wrap them in a CLI or run them via an exposed HTTP endpoint.
  • declarative: just specify the version you want and the library figures out if it needs an upgrade, downgrade or no action.

Example usage

from pathlib import Path

import asyncpg
from asyncpg_trek import plan, execute, Direction
from asyncpg_trek.asyncpg import AsyncpgBackend

MIGRATIONS_DIR = Path(__file__).parent / "migrations"

async def migrate(
    conn: asyncpg.Connection,
    target_revision: str,
) -> None:
    backend = AsyncpgBackend(conn)
    async with backend.connect() as conn:
        planned = await plan(conn, backend, MIGRATIONS_DIR, target_revision=target_revision, direction=Direction.up)
        await execute(conn, backend, planned)

You could make this an entrypoint in a docker image, an admin endpoint in your API or a helper function in your tests (or all of the above). How you run your migrations depends on the complexity of your system. For example, for simple systems it may be easy to run migrations on app startup based on a hardcoded revision. For more complex systems you may want to run migrations manually or via an admin API.

See this release on GitHub: v0.4.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

asyncpg_trek-0.4.0.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

asyncpg_trek-0.4.0-py3-none-any.whl (9.5 kB view details)

Uploaded Python 3

File details

Details for the file asyncpg_trek-0.4.0.tar.gz.

File metadata

  • Download URL: asyncpg_trek-0.4.0.tar.gz
  • Upload date:
  • Size: 7.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1023-azure

File hashes

Hashes for asyncpg_trek-0.4.0.tar.gz
Algorithm Hash digest
SHA256 3a04c096ae896913d369329a96253b309bf095b1d4cd029ecad43c19dc5cf4da
MD5 108859157e705cca403506cc280fc1b6
BLAKE2b-256 15df3dbad74b63ca14a47083849842a5ad6964a2b78d91ae09ae28e0f35f4971

See more details on using hashes here.

File details

Details for the file asyncpg_trek-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: asyncpg_trek-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 9.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1023-azure

File hashes

Hashes for asyncpg_trek-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 31348799d67704ffd0e4c0a0ab419b0687449271796214ca7a08c5e1ef68925e
MD5 a4cba0eff928f3ee453d581ce99f9891
BLAKE2b-256 b081d79224c679505e5224f921aaec09a6d667959b04fb35cd94d942e032c638

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page