Migrations: run initial schema file...

...when no migrations have ever been applied
This commit is contained in:
Thomas Gelf 2016-02-17 15:42:34 +01:00
parent c3ac57ede0
commit afe0bfb373
2 changed files with 28 additions and 13 deletions

View File

@ -27,7 +27,9 @@ class Migration
public function apply(Db $connection)
{
$db = $connection->getDbAdapter();
$queries = preg_split('/[\n\s\t]*\;[\n\s\t]*/s', $this->sql, -1, PREG_SPLIT_NO_EMPTY);
// TODO: this is fagile and depends on accordingly written schema files:
$queries = preg_split('/[\n\s\t]*\;[\n\s\t]+/s', $this->sql, -1, PREG_SPLIT_NO_EMPTY);
if (empty($queries)) {
throw new IcingaException(
@ -37,21 +39,17 @@ class Migration
}
try {
$db->beginTransaction();
foreach ($queries as $query) {
$db->exec($query);
}
$db->commit();
} catch (Exception $e) {
$db->rollback();
throw new IcingaException(
'Migration %d failed: %s',
'Migration %d failed (%s) while running %s',
$this->version,
$e->getMessage()
$e->getMessage(),
$query
);
}

View File

@ -74,6 +74,11 @@ class Migrations
public function listPendingMigrations()
{
$lastMigration = $this->getLastMigrationNumber();
if ($lastMigration === 0) {
return array(0);
}
return $this->listMigrationsAfter($this->getLastMigrationNumber());
}
@ -101,11 +106,15 @@ class Migrations
public function loadMigrationFile($version)
{
$filename = sprintf(
'%s/upgrade_%d.sql',
$this->getMigrationsDir(),
$version
);
if ($version === 0) {
$filename = $this->getFullSchemaFile();
} else {
$filename = sprintf(
'%s/upgrade_%d.sql',
$this->getMigrationsDir(),
$version
);
}
return file_get_contents($filename);
}
@ -133,4 +142,12 @@ class Migrations
return $this->migrationsDir;
}
protected function getFullSchemaFile()
{
return dirname(dirname(dirname(__DIR__)))
. '/schema/'
. $this->connection->getDbType()
. '.sql';
}
}