zitansmail / migration-orderer
Automatically order Laravel migrations based on foreign key dependencies to prevent constraint errors
Installs: 11
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/zitansmail/migration-orderer
Requires
- php: ^8.1
- illuminate/console: ^10.0 || ^11.0 || ^12.0
- illuminate/database: ^10.0 || ^11.0 || ^12.0
- illuminate/support: ^10.0 || ^11.0 || ^12.0
Requires (Dev)
- orchestra/testbench: ^10.6 || ^11.0
- pestphp/pest: ^3.8
README
Automatically analyze and reorder Laravel migrations based on foreign key dependencies. Prevent foreign key constraint errors by ensuring tables are created in the correct order.
composer require zitansmail/migration-orderer --dev
๐ฏ The Problem
Ever encountered this error when running migrations?
SQLSTATE[HY000]: General error: 1005 Can't create table `posts` (errno: 150 "Foreign key constraint is incorrectly formed")
This happens when migrations create foreign keys to tables that don't exist yet. Traditional solutions require manually renaming migration files or creating migrations in perfect chronological order.
๐ก The Solution
MigrationOrderer automatically:
- Scans your migrations for foreign key dependencies
- Builds a dependency graph using topological sorting
- Reorders files to ensure dependencies come first
- Shows you exactly what needs to be fixed
๐ Features
- ๐ Smart Detection: Finds
foreignId(),constrained(),foreignIdFor(), and legacy foreign keys - ๐งฉ Topological Sort: Uses graph algorithms to compute safe execution order
- ๐๏ธ Rich Preview: Shows current vs computed positions with dependency details
- ๐ก๏ธ Circular Detection: Identifies and reports circular dependencies with clear error messages
- ๐ Safe Reordering: Renames files while maintaining full undo capability
- ๐พ State Management: Tracks changes in database for reliable undo operations
- ๐ Flexible Paths: Works with custom migration directories and modular setups
- โ Production Ready: Comprehensive test coverage and error handling
โ Requirements
- PHP 8.1+
- Laravel 10.x / 11.x / 12.x
๐ฆ Installation
composer require zitansmail/migration-orderer --dev
That's it! The package auto-registers and creates its tracking table automatically when needed. No manual migrations required.
๐ Usage
1. Preview Dependencies (Safe, No Changes)
php artisan migrate:ordered --preview
Example Output:
+-------------+----------------------+-------------+---------------+------------------+------------------------+
| # (Computed)| Migration | Current Pos | Status | Dependencies | Issue |
+-------------+----------------------+-------------+---------------+------------------+------------------------+
| 1 | create_users_table | 2 | NEEDS REORDER | - | - |
| 2 | create_posts_table | 1 | NEEDS REORDER | create_users_... | Depends on: create_... |
+-------------+----------------------+-------------+---------------+------------------+------------------------+
โ ๏ธ 1 migration(s) need reordering for dependency safety.
2. Reorder Files
php artisan migrate:ordered --reorder
With confirmation bypass (CI/automation):
php artisan migrate:ordered --reorder --force
3. Undo Last Reorder
php artisan migrate:ordered --undo-last
4. Custom Migration Paths
php artisan migrate:ordered --preview --path=modules/Blog/database/migrations
๐ Supported Foreign Key Patterns
The scanner detects all modern Laravel foreign key patterns:
// โ Modern foreignId with implicit constraint $table->foreignId('user_id')->constrained(); // โ Modern foreignId with explicit table $table->foreignId('author_id')->constrained('users'); // โ ForeignIdFor helper $table->foreignIdFor(User::class); $table->foreignIdFor(User::class, 'author_id'); // โ Legacy foreign key syntax $table->foreign('user_id')->references('id')->on('users'); // โ Legacy unsigned big integer (partial detection) $table->unsignedBigInteger('user_id'); // โ ๏ธ Polymorphic relationships (detected but no dependency) $table->morphs('commentable'); $table->uuidMorphs('taggable');
๐ Workflow Examples
Basic Workflow
# 1. Check current state php artisan migrate:ordered --preview # 2. Fix ordering if needed php artisan migrate:ordered --reorder # 3. Run migrations normally php artisan migrate # 4. Undo if something goes wrong php artisan migrate:ordered --undo-last
Team Development
# Before merging a feature branch git checkout feature/user-system php artisan migrate:ordered --preview php artisan migrate:ordered --reorder --force git add database/migrations/ git commit -m "Fix migration dependency order"
๐จ Error Handling
Circular Dependencies
Migration Orderer Error: Circular dependency detected: create_users_table.php -> create_roles_table.php -> create_users_table.php
Solution: Break the cycle by:
- Moving foreign keys to separate migrations
- Using nullable foreign keys initially
- Deferring constraints with
Schema::enableForeignKeyConstraints()
Missing Dependencies
The preview shows missing tables that your migrations reference but don't create:
Missing: ["external_api_users", "legacy_data"]
๐งญ Command Reference
php artisan migrate:ordered [options] Options: --preview Show dependency analysis without making changes --reorder Rename files to match computed order --undo-last Restore files from last reorder operation --path=PATH Custom migrations directory --force Skip confirmation prompts
๐ Safety Features
- Preview First: Always shows what will change before making modifications
- Atomic Operations: File renames are tracked; failures can be undone
- State Persistence: Every reorder is logged in the database
- Backup Strategy: Undo capability restores exact previous state
- Non-Destructive: Default mode makes no changes to your files
- Validation: Detects and prevents circular dependencies
๐ก๏ธ Best Practices
Development Workflow
- Always preview first to understand dependencies
- Commit before reordering for easy rollback
- Use feature branches for complex schema changes
- Test migrations in staging before production
Schema Design
- Avoid circular foreign key dependencies
- Consider nullable foreign keys for complex relationships
- Use pivot tables for many-to-many relationships
- Plan table creation order during initial design
Team Collaboration
- Run
--previewbefore pushing migration changes - Include reordering in your CI/CD pipeline
- Document complex dependency relationships
- Use consistent naming conventions
๐งช Testing
The package includes focused tests covering core functionality:
# Run the test suite composer test # With coverage composer test-coverage
Essential test coverage:
- โ Command Interface - Preview, reorder, undo operations
- โ Dependency Detection - All foreign key patterns and missing dependencies
- โ Circular Dependencies - Detection and error handling
- โ File Operations - Safe reordering with automatic table creation
๐ค Contributing
We welcome contributions! Here's how you can help improve MigrationOrderer:
Quick Start
git clone https://github.com/zitansmail/migration-orderer cd migration-orderer composer install composer test
Contributing Guidelines
๐ Reporting Bugs
- Check existing issues before creating new ones
- Include Laravel version, PHP version, and error details
- Provide minimal reproduction steps
โจ Suggesting Features
- Open an issue with a clear description
- Explain the use case and expected behavior
- Include code examples if applicable
๐ง Code Contributions
- Fork the repository
- Create a feature branch:
git checkout -b feature/your-feature - Write tests for new functionality
- Ensure all tests pass:
composer test - Follow PSR-12 coding standards
- Submit a pull request with clear description
๐ Documentation
- Fix typos and improve clarity
- Add examples for complex features
- Update README when adding new functionality
Development Guidelines
- Write tests for all new features
- Keep backwards compatibility
- Follow existing code patterns
- Add meaningful commit messages
๐ License
MIT License. See LICENSE for details.
๐ Learn More
๐ Technical Deep Dive Read the complete story behind MigrationOrderer's development: Solving Laravel Migration Dependency Hell: Building MigrationOrderer Package
The blog post covers:
- The problem and motivation behind the package
- Technical implementation details and algorithms
- Real-world usage patterns and team workflows
- Development challenges and lessons learned
- Future enhancements and roadmap
๐ Credits
Created by Zitane Smail
Built with โค๏ธ for the Laravel community.