Metadata-Version: 2.1
Name: django-migrations-diff
Version: 2.0.5
Summary: CLI for comparing Django migrations between two snapshots.
Home-page: https://github.com/deniskrumko/django-migrations-diff
Author: Denis Krumko
Author-email: dkrumko@gmail.com
License: MIT
Keywords: CLI,Django,Migrations,Diff
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Natural Language :: English
Classifier: Environment :: Console
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Topic :: Software Development :: Libraries
Classifier: Topic :: Utilities
Requires-Python: >=3.6
Requires-Dist: requests

django-migrations-diff
======================

.. image:: https://img.shields.io/pypi/v/django-migrations-diff.svg
    :target: https://pypi.org/project/django-migrations-diff/
    :alt: PyPI version

.. image:: https://img.shields.io/pypi/pyversions/django-migrations-diff.svg
    :target: https://pypi.org/project/django-migrations-diff/
    :alt: Python versions

.. image:: https://img.shields.io/pypi/l/django-migrations-diff.svg
    :target: https://raw.githubusercontent.com/deniskrumko/django-migrations-diff/master/LICENSE
    :alt: License


CLI to compare Django migrations between two snapshots.

This may be useful when you need to compare migrations in the same app between different branches.

Installation
^^^^^^^^^^^^
.. code-block:: bash

    pip install django-migrations-diff

Requirements
^^^^^^^^^^^^

- Python 3.6 or higher

How to use
^^^^^^^^^^

.. code-block:: bash

    # show help
    mdiff help

    # Create migrations snapshot
    mdiff <snapshot>

    # Compare two snapshots
    mdiff <snapshot_1> <snapshot_2>

    # Compare two snapshots (get number of diffent migrations)
    mdiff <snapshot_1> <snapshot_2> --number

    # List of all snapshots
    mdiff list

    # Remove all or specific snapshots
    mdiff rm all
    mdiff rm <snapshot_1> <snapshot_2>

    # Get current version
    mdiff -v

Example
^^^^^^^

For example, you need to compare "master" and "develop" branches.

.. code-block:: bash

  git checkout master # go to "master" branch

  mdiff master # create "master" snapshot

  git checkout develop # go to "develop" branch

  mdiff develop # create "develop" shapshot

  mdiff master develop # compare two snapshots


Output will be like:

.. code-block:: bash

  ┌─────────────┬───────────────────┬───────────────────┐
  │ APPLICATION │ MASTER            │ DEVELOP           │
  ├─────────────┼───────────────────┼───────────────────┤
  │ app.authors │ 0004_migration.py │ ---               │
  │             │ ---               │ 0005_migration.py │
  ├─────────────┼───────────────────┼───────────────────┤
  │ app.users   │ 0003_migration.py │ 0003_migration.py │
  └─────────────┴───────────────────┴───────────────────┘
   Stats for snapshot DEVELOP: +1 -1 *1

Explanation:

1. Snapshot MASTER has 0004_migration.py but DEVELOP misses it
2. Snapshot DEVELOP has 0005_migration.py but MASTER misses it
3. Both MASTER and DEVELOP have 0003_migration.py migration, but it differs inside
4. Stats show that DEVELOP snapshot has 1 new, 1 missing and 1 changed migration

CI/CD configuration
^^^^^^^^^^^^^^^^^^^

This package also can be used to detect new migrations in CI/CD pipelines.
For example, following stage in **.gitlab-ci.yml** will fail if there are new migrations in current
branch in comparison to master branch.

.. code-block:: bash

  chechcheck:
    stage: tests
    script:
      - pip install django-migrations-diff==2.0.4  # PLEASE, CHECK CURRENT VERSION
      - git merge-base origin/master HEAD | xargs git checkout
      - mdiff master
      - git checkout ${CI_COMMIT_REF_NAME}
      - mdiff ${CI_COMMIT_REF_NAME}
      - mdiff master ${CI_COMMIT_REF_NAME}
      - (if [[ $(mdiff master ${CI_COMMIT_REF_NAME} --number) == 0 ]]; then echo "No new migrations"; else exit 1; fi;)
    allow_failure: true

**NOTE**: This is not full stage descriptions, this is only example.


