Skip to main content

Fix conflicting Django migrations (numbered) with robust git + worktree support

Project description

django-modern-migration-fixer

CI

Fix conflicting Django migrations (numbered styles) using plain git CLI, with robust support for normal repos and git worktrees. No GitPython dependency.

This is a fork and drop-in replacement for django-migration-fixer which is not actively maintained by the author.

  • Detects conflicting leaf nodes and renumbers local migrations to form a single linear chain.
  • Rewrites dependencies to point to the last migration on the default branch.
  • Works in git worktrees by discovering the repo root via git rev-parse --show-toplevel.

Install

uv pip install django-modern-migration-fixer

Add to your Django settings:

INSTALLED_APPS = [
    # ...
    "django_modern_migration_fixer",
    # ...
]

Usage

./manage.py makemigrations --fix [apps...]

Useful flags:

  • -b, --default-branch: Name of the default branch (default: master).
  • -r, --remote: Git remote (default: origin).
  • -s, --skip-default-branch-update: Skip fetching remote default branch.
  • -f, --force-update: Force update the default branch refs before fixing.

Examples:

./manage.py makemigrations --fix
./manage.py makemigrations --fix -b master --skip-default-branch-update
./manage.py makemigrations --fix -r upstream --force-update

How it works

  • On a Conflicting migrations error, the command:
    • Verifies the repo is clean.
    • Optionally fetches the default branch.
    • Resolves default-branch and HEAD SHAs robustly.
    • Loads the migration graph and finds conflicts per app.
    • Filters changed migration files under the app’s migration folder between default SHA and HEAD.
    • Renumbers local files and rewrites dependencies to form a single chain.

Limitations

  • Only supports numbered migration file names (e.g., 0001_initial). Non-numbered names fail fast with a clear message.
  • Cross-app dependency rewrites beyond simple renumbering are out of scope.

Make targets

Convenient shortcuts are available via make:

  • make tests — Run unit and e2e tests (unittest discovery).
  • make tests-unit — Discover and run tests under tests/unit.
  • make tests-e2e — Discover and run tests under tests/e2e (safe if empty).
  • make builduv sync --extra dev then uv build to produce wheels/sdist.
  • make distributetwine check then upload artifacts in dist/ to PyPI.

Notes:

  • Test runs set PYTHONPATH=src so the package imports without installation.
  • build and distribute require uv to be installed and available on PATH.

License

MIT

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

django_modern_migration_fixer-0.1.2.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_modern_migration_fixer-0.1.2-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file django_modern_migration_fixer-0.1.2.tar.gz.

File metadata

File hashes

Hashes for django_modern_migration_fixer-0.1.2.tar.gz
Algorithm Hash digest
SHA256 bbd49092baa7d4641328df8a10588a428b961de0ca687b4e5d82e80acb2bb328
MD5 c5ff1dced7c4e10806b734e1f637734f
BLAKE2b-256 4a57b81a196198ed1893c18349dffcc0785572d594233d6ceda43774eed9f01d

See more details on using hashes here.

File details

Details for the file django_modern_migration_fixer-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for django_modern_migration_fixer-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9faf26379cabe5f230869ee5205e640d90bf53a5d66b71d87c3b45ef4dab22c7
MD5 39bfd5af06410ab87a81073c560491a6
BLAKE2b-256 e2e842f3c8f3155353e0349817609af7a9c43128f74985b5a5cd4769174f947b

See more details on using hashes here.

Supported by

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