Metadata-Version: 2.3
Name: migropy
Version: 0.4.0
Summary: Lightweight and extensible Python library for managing database migrations
License: MIT
Keywords: database,migrations,postgresql,mysql,sql,cli
Author: fredimatteo
Author-email: matteofredi.developer@gmail.com
Requires-Python: >=3.10.0,<4.0.0
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Database
Requires-Dist: mysql-connector-python (>=9.2.0,<10.0.0)
Requires-Dist: psycopg (>=3.2.6,<4.0.0)
Requires-Dist: pytest-mock (>=3.14.0,<4.0.0)
Project-URL: Homepage, https://github.com/fredimatteo/migropy/blob/develop/README.md
Project-URL: Repository, https://github.com/fredimatteo/migropy.git
Description-Content-Type: text/markdown

![Python versions](https://img.shields.io/pypi/pyversions/migropy?style=flat-square&logo=python&logoColor=white&color)
![Test](https://img.shields.io/github/actions/workflow/status/fredimatteo/migratron/test.yml?style=flat-square&logo=github&logoColor=white&color&label=Test)

# 🛠️ Migropy

**Migropy** is a lightweight and extensible Python library for managing **database migrations**.  
Designed for simplicity and flexibility, it helps teams apply, track, and version-control schema changes across multiple
environments.

---

## 📚 Table of Contents

- [🚀 Features](#-features)
- [📦 Installation](#-installation)
- [📖 How to use - CLI](#-how-to-use---cli)
    - [1. Initialize a new migration project](#1-initialize-a-new-migration-project)
    - [2. Fill the config.ini file](#2-fill-the-configini-file)
    - [3. 🔐 Using a .env file or environment variables](#3-using-a-env-file-or-environment-variables)
    - [4. Create a new migration](#3-create-a-new-migration)
    - [5. Apply the migrations](#4-apply-the-migrations)
    - [6. Downgrade the migrations](#5-downgrade-the-migrations)
    - [7. Rollback the migrations](#6-rollback-the-migrations)
- [🐍 How to use - Python](#-how-to-use---python)
- [📄 Migration example](#-migration-example)
- [⚙️ Available commands](#-available-commands)
- [🧪 Running Unit Tests](#-running-unit-tests)
- [📝 Changelog](#-changelog)
- [🤝 Contributing](#-contributing)
- [📫 Support](#-support)
- [📄 License](#-license)

---

## 🚀 Features

- ✅ Versioned migrations with up/down support
- ✅ Compatible with PostgreSQL & MySQL
- ✅ CLI for common migration operations
- ✅ Safe and idempotent execution
- ✅ Customizable migration directory structure

---

## 📦 Installation

```bash
pip install migropy
```

---

## 📖 How to use - CLI

### 1. Initialize a new migration project

This command will create a new directory called `migropy` with the necessary files to manage your migrations & db
parameters.

```bash
migropy init <optional_migration_directory_name>
```

### 2. Fill the config.ini file

This file is generated in your current directory and contains the database connection parameters and the path to the
migration

```ini
[database]
# database connection parameters
# available types: postgres, mysql
host = localhost
port = 5432
user = postgres
password = postgres
dbname = my_database
type = postgres # or mysql

[migrations]
# path to migration scripts
# use forward slashes (/) also on windows to provide an os agnostic path
script_location = migropy
# option available with postgres
base_schema = public

[logger]
# available levels: DEBUG, INFO, WARNING, ERROR, CRITICAL
level = INFO
```

### 3. 🔐 Using a .env file or environment variables

Migropy supports environment variables and .env files to avoid committing credentials or secrets to your repository.

This allows usage in:

* Local development
* CI/CD pipelines
* Docker
* Production environments

#### 🔎 How it works

Migropy loads configuration in this order:

1. Environment variables
2. .env file (if present in the current working directory)<br>

👉 Environment variables always override values from the .ini file.

#### ⚙️ Supported environment variables

| Environment Variable      | Description                                |
|---------------------------|--------------------------------------------|
| `MIGROPY_DB_HOST`         | Database host                              |
| `MIGROPY_DB_PORT`         | Database port                              |
| `MIGROPY_DB_USER`         | Database user                              |
| `MIGROPY_DB_PASSWORD`     | Database password                          |
| `MIGROPY_DB_NAME`         | Database name                              |
| `MIGROPY_DB_TYPE`         | Database type (e.g., postgres, mysql)      |
| `MIGROPY_MIGRATIONS_PATH` | Path to migration scripts                  |
| `MIGROPY_BASE_SCHEMA`     | Base schema (Postgres only)                |
| `MIGROPY_LOG_LEVEL`       | Logging level (e.g., DEBUG, INFO, WARNING) |

### 4. Create a new migration

This command will create a new migration file in the `migropy/versions` directory with the following template:

```bash
migropy generate 'migration name'
```

```sql
-- Up migration

-- Down migration
```

### 5. Apply the migrations

This command will apply all the migrations in the `migrations` directory. Please note the migrations are applied in
the prefix order.

```bash
migropy upgrade
```

### 6. Downgrade the migrations

This command will downgrade all the migrations in the `migrations` directory. Please note the migrations are
downgraded in
the prefix order.

```bash
migropy downgrade
```

### 7. Rollback the migrations

This command will rollback the last n migrations in the `migrations` directory, starting from the last one executed.

```bash
migropy rollback <n>
```

---

## 🐍 How to use - Python

You can also use **Migropy** as a library in your Python code. Here is an example of how to use it:

```python
# Importing the function to load the migration configuration
from migropy.configuration_parser import load_config

# Importing the Postgres database adapter
from migropy.databases.postgres import Postgres

# Importing the common database configuration structure
from migropy.databases.commons import DbConfig

# Importing the migration engine responsible for applying migrations
from migropy.migration_engine import MigrationEngine

# Create a database configuration object with connection parameters
db_config = DbConfig(
    host="localhost",  # Database server hostname or IP
    port=5432,  # Default PostgreSQL port
    user="user",  # Username to connect to the database
    password="password",  # Password for the given user
    database="test"  # Name of the target database
)

# Instantiate a Postgres database connection using the provided configuration
db = Postgres(db_config)

# Create a MigrationEngine instance with:
# - the database connection
# - the loaded configuration (usually from a file like migropy.ini)
engine = MigrationEngine(db=db, config=load_config())

# Initialize the migropy environment and create the necessary tables
# use it just once!!!
engine.init()

# Generate a new migration revision with a descriptive name
engine.generate_revision(revision_name='first revision')

# Apply all pending migrations to upgrade the database schema
engine.upgrade()

```

---

## 📄 Migration example

```sql
-- Up migration
CREATE TABLE users
(
    id    SERIAL PRIMARY KEY,
    name  VARCHAR(100) NOT NULL,
    email VARCHAR(100) NOT NULL
);

-- Down migration
DROP TABLE users;
```

---

## ⚙️ Available commands

| Comando                                   | Descrizione                   |
|-------------------------------------------|-------------------------------|
| `migropy init <optional_folder_name:str>` | Init migratron environment    |
| `migropy generate <name:str>`             | Generate a new sql migration  |
| `migropy upgrade`                         | Apply all the migration       |
| `migropy downgrade`                       | Rollback all revisions        |
| `migropy rollback <n:int>`                | Rollback n revisions          |
| `migropy list `                           | Show current migration status |

---

## 🧪 Running Unit Tests

To run the unit tests using poetry, you can use the following command:

```bash
poetry run pytest --rootdir=tests
```

---

## 📝 Changelog

See the full [CHANGELOG.md](https://github.com/fredimatteo/migratron/blob/main/CHANGELOG.md)

### Latest Changes

- **0.4.0** - Dependencies update, custom migration directory name & env variables support
- **0.3.1** - Code refactor to improve readability and maintainability
- **0.3.0** - Add rollback command
- **0.2.2** – Commands refactor & usage from python code
- **0.2.1** – Increase minimum python version to 3.10 & refactor MigrationEngine
- **0.2.0** – MySQL database support
- **0.1.1** – Initial project setup with PostgreSQL

---

## 🤝 Contributing

We welcome contributions!  
To get started:

1. Fork the repository
2. Create a new branch (`git checkout -b feature/your-feature`)
3. Commit your changes
4. Open a pull request 🚀

---

## 📫 Support

For issues, feature requests or general questions, open an issue
on [GitHub Issues](https://github.com/fredimatteo/migratron/issues).


---

## 📄 License

MIT License © 2025 — teoxy

