Add human readable description to migration steps

Signed-off-by: Robin Appelman <robin@icewind.nl>
This commit is contained in:
Robin Appelman 2018-04-12 17:47:40 +02:00 committed by Roeland Jago Douma
parent 2dd49206c7
commit b40629ac8c
No known key found for this signature in database
GPG key ID: F941078878347C0C
6 changed files with 80 additions and 5 deletions

View file

@ -58,7 +58,14 @@ class StatusCommand extends Command implements CompletionAwareInterface {
$infos = $this->getMigrationsInfos($ms);
foreach ($infos as $key => $value) {
$output->writeln(" <comment>>></comment> $key: " . str_repeat(' ', 50 - strlen($key)) . $value);
if (is_array($value)) {
$output->writeln(" <comment>>></comment> $key:");
foreach ($value as $subKey => $subValue) {
$output->writeln(" <comment>>></comment> $subKey: " . str_repeat(' ', 46 - strlen($subKey)) . $subValue);
}
} else {
$output->writeln(" <comment>>></comment> $key: " . str_repeat(' ', 50 - strlen($key)) . $value);
}
}
}
@ -96,6 +103,7 @@ class StatusCommand extends Command implements CompletionAwareInterface {
$numExecutedUnavailableMigrations = count($executedUnavailableMigrations);
$numNewMigrations = count(array_diff(array_keys($availableMigrations), $executedMigrations));
$pending = $ms->describeMigrationStep('lastest');
$infos = [
'App' => $ms->getApp(),
@ -110,6 +118,7 @@ class StatusCommand extends Command implements CompletionAwareInterface {
'Executed Unavailable Migrations' => $numExecutedUnavailableMigrations,
'Available Migrations' => count($availableMigrations),
'New Migrations' => $numNewMigrations,
'Pending Migrations' => count($pending) ? $pending : 'None'
];
return $infos;

View file

@ -30,6 +30,13 @@ use OCP\Migration\IOutput;
* Delete the admin|personal sections and settings tables
*/
class Version14000Date20180129121024 extends SimpleMigrationStep {
public function name(): string {
return 'Drop obsolete settings tables';
}
public function description(): string {
return 'Drops the following obsolete tables: "admin_sections", "admin_settings", "personal_sections" and "personal_settings"';
}
/**
* @param IOutput $output

View file

@ -41,6 +41,14 @@ class Version14000Date20180404140050 extends SimpleMigrationStep {
$this->connection = $connection;
}
public function name(): string {
return 'Add lowercase user id column to users table';
}
public function description(): string {
return 'Adds "uid_lower" column to the users table and fills the column to allow indexed case-insensitive searches';
}
/**
* @param IOutput $output
* @param \Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper`

View file

@ -386,15 +386,37 @@ class MigrationService {
}
}
/**
* Get the human readable descriptions for the migration steps to run
*
* @param string $to
* @return string[] [$name => $description]
*/
public function describeMigrationStep($to = 'latest') {
$toBeExecuted = $this->getMigrationsToExecute($to);
$description = [];
foreach ($toBeExecuted as $version) {
$migration = $this->createInstance($version);
if ($migration->name()) {
$description[$migration->name()] = $migration->description();
}
}
return $description;
}
/**
* @param string $version
* @return mixed
* @return IMigrationStep
* @throws \InvalidArgumentException
*/
protected function createInstance($version) {
$class = $this->getClass($version);
try {
$s = \OC::$server->query($class);
if (!$s instanceof IMigrationStep) {
throw new \InvalidArgumentException('Not a valid migration');
}
} catch (QueryException $e) {
if (class_exists($class)) {
$s = new $class();
@ -414,9 +436,6 @@ class MigrationService {
*/
public function executeStep($version) {
$instance = $this->createInstance($version);
if (!$instance instanceof IMigrationStep) {
throw new \InvalidArgumentException('Not a valid migration');
}
$instance->preSchemaChange($this->output, function() {
return new SchemaWrapper($this->connection);

View file

@ -29,6 +29,21 @@ use OCP\DB\ISchemaWrapper;
* @since 13.0.0
*/
interface IMigrationStep {
/**
* Human readable name of the migration step
*
* @return string
* @since 14.0.0
*/
public function name(): string;
/**
* Human readable description of the migration steps
*
* @return string
* @since 14.0.0
*/
public function description(): string;
/**
* @param IOutput $output

View file

@ -29,6 +29,23 @@ use OCP\DB\ISchemaWrapper;
* @since 13.0.0
*/
abstract class SimpleMigrationStep implements IMigrationStep {
/**
* Human readable name of the migration step
*
* @return string
*/
public function name(): string {
return '';
}
/**
* Human readable description of the migration step
*
* @return string
*/
public function description(): string {
return '';
}
/**
* @param IOutput $output