Static migration conflict checker for Django
Project description
Note: this project is not actively maintained. It’s also kind of an ugly hack, and most probably there are better ways to solve the same problem these days.
The package allows to detect migration conflicts in Django application via static code analysis. In other words, it doesn’t run or import any of your code, but finds and parses Django migration files.
The package should work fine with Python 3.6+, and migrations generated by Django 1.7 and later.
Example:
>>> from django_migration_checker import get_conflicts >>> get_conflicts(app_dir='./django-project/apps') [('accounts', ['0001_initial', '0002_new_migration'])]
Free software: MIT license
Installation
pip install django-migration-checker
Why?
The initial goal was to have some way to quickly analyze pull requests to a Django project and detect if the new changes introduce migration conflicts if they are merged to master.
Here are a few features:
Fast
No database connections, heavy modules loading, or checks are performed, so why would it be slow?
No up-to-date environment needed
You don’t need to have a working Django environment (valid settings.py file, all installed dependencies, etc.) to use this package. The only requirement is to have properly generated migration files.
No dependencies
The package doesn’t require Django itself, NumPy, left-pad, or any other packages.
Command-line tool
After installing the package you can use the command-line script django-find-conflicts to detect migration conflicts from your console.
Here’s how it looks like:
$ django-find-conflicts ./django-project/apps [('accounts', ['0001_initial', '0002_new_migration'])] $ django-find-conflicts ./another-django-project/apps No conflicts detected.
Credits
This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.
# Changelog
## [0.8.0] - 2023-01-05
Support multiple projects when in CLI mode ([#12](https://github.com/tonyo/django-migration-checker/pull/12))
## [0.7.1] - 2022-07-31
Fix error on double quote and multiple dependencies ([#11](https://github.com/tonyo/django-migration-checker/pull/11))
## [0.7.0] - 2021-12-26
Accept both single and double quotes ([#9](https://github.com/tonyo/django-migration-checker/pull/9))
Drop support for Python 2.7 and 3.5
Move to GitHub Actions
Get rid of Travis
## [0.6.0] - 2020-12-05
Exit with code 1 when conflicts are found ([#7](https://github.com/tonyo/django-migration-checker/pull/7))
## [0.1.0] - 2016-09-09
First release on PyPI.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file django-migration-checker-0.8.0.tar.gz
.
File metadata
- Download URL: django-migration-checker-0.8.0.tar.gz
- Upload date:
- Size: 19.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4bcabbf5821e14cee65fcda47569f741a7148547517bf0ce75df2eaa035da62b |
|
MD5 | df2d66ead2f0c66700abd6f5dfb0cec3 |
|
BLAKE2b-256 | a6993a16e330a0a2ab8dec2ea9eaa7a4aeeaa3154730297c8e3c76395422a1d1 |
File details
Details for the file django_migration_checker-0.8.0-py2.py3-none-any.whl
.
File metadata
- Download URL: django_migration_checker-0.8.0-py2.py3-none-any.whl
- Upload date:
- Size: 6.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 65d763d6d0dda30ed9429d3691a49289a3a0e82fd5146a5ecccf11f12de67290 |
|
MD5 | a0861b5e7c7f2841e591a7d04b1b9994 |
|
BLAKE2b-256 | b529bd2e6712a230db1e3c65be19b4aa5eb36ac4cf3d337e0d6e5b525c286a58 |