dreadlabs/app-migration

This package is abandoned and no longer maintained. No replacement package was suggested.

Provides a package for adding runtime migrations to an application.

0.1.1 2015-10-01 09:53 UTC

This package is not auto-updated.

Last update: 2022-06-25 06:20:52 UTC


README

Provides an opinionated, ready-to-use way to integrate runtime migration into your PHP application.

Status

Build Status Coverage Status SensioLabsInsight Code Climate Scrutinizer Code Quality

Installation

~ $ php composer.phar require dreadlabs/app-migration:~0.1.1

Components

Interfaces

  • LockInterface - Adapter interface to locking library
  • LoggerInterface - An slimmed down version of the PSR-3 logger interface
  • MediatorInterface - This is the glue between lock, logger and migrator
  • MigratorInterface -Adapter interface to migration library

Exceptions

  • LockingException - If anything goes wrong during locking
  • MigrationException - If a migration can't be executed. Exception code is the version number of the migration which produced the exception.
  • TopologyViolationException - If one or more unprocessed migrations are younger than the latest processed migration.

Companion packages

Opinionated - why?

Topological assumption

I believe, there should be only one direction during migration: "up". This belief comes from looking to migrations like they are ordered on a time axis. You can't go back in time - can you? - and therefore no way to migrate "down".

If you have the need to migrate down (e.g. during testing), just create another migration which rolls back the last one. Then decide which migrations to drop and which can go into CVS.

Logging

Logging is essential during migration. If something went wrong, you need to know as soon as possible what is the problem. Logging is a first class citizen in the mediator. If you don't need logging, just pass in a NullLogger and you're good to go.

License

MIT, © 2015 Thomas Juhnke