diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2014-07-07 15:50:34 +0200 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2014-07-07 15:50:34 +0200 |
commit | 268af9039ae4671be50863f852def8a0db0c7e08 (patch) | |
tree | fa126dd1b7d5097e7653345b30f45bef7bdfe847 | |
parent | b271e05bc9066157a7af62062ad2d47e73dd54b7 (diff) | |
parent | b091b15f0bc683e15f5f6ee2414c265ac7a3cdbb (diff) | |
download | nextcloud-server-268af9039ae4671be50863f852def8a0db0c7e08.tar.gz nextcloud-server-268af9039ae4671be50863f852def8a0db0c7e08.zip |
Merge pull request #9492 from owncloud/repait-innodb-master
MySQL: adding repair step to convert MyIsam tables to InnoDB
-rw-r--r-- | lib/private/repair.php | 1 | ||||
-rw-r--r-- | lib/repair/innodb.php | 51 | ||||
-rw-r--r-- | tests/lib/repair/repairinnodb.php | 65 |
3 files changed, 117 insertions, 0 deletions
diff --git a/lib/private/repair.php b/lib/private/repair.php index 14a917be32c..89886dd9316 100644 --- a/lib/private/repair.php +++ b/lib/private/repair.php @@ -81,6 +81,7 @@ class Repair extends BasicEmitter { */ public static function getBeforeUpgradeRepairSteps() { return array( + new \OC\Repair\InnoDB() ); } diff --git a/lib/repair/innodb.php b/lib/repair/innodb.php new file mode 100644 index 00000000000..4d58bf64a9e --- /dev/null +++ b/lib/repair/innodb.php @@ -0,0 +1,51 @@ +<?php +/** + * Copyright (c) 2014 Thomas Müller <deepdiver@owncloud.com> + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OC\Repair; + +use Doctrine\DBAL\Platforms\MySqlPlatform; +use OC\Hooks\BasicEmitter; + +class InnoDB extends BasicEmitter implements \OC\RepairStep { + + public function getName() { + return 'Repair MySQL database engine'; + } + + /** + * Fix mime types + */ + public function run() { + $connection = \OC_DB::getConnection(); + if (!$connection->getDatabasePlatform() instanceof MySqlPlatform) { + $this->emit('\OC\Repair', 'info', array('Not a mysql database -> nothing to no')); + return; + } + + $tables = $this->getAllMyIsamTables($connection); + foreach ($tables as $table) { + $connection->exec("ALTER TABLE $table ENGINE=InnoDB;"); + $this->emit('\OC\Repair', 'info', array("Fixed $table")); + } + } + + /** + * @param \Doctrine\DBAL\Connection $connection + * @return string[] + */ + private function getAllMyIsamTables($connection) { + $dbName = \OC::$server->getConfig()->getSystemValue("dbname"); + $result = $connection->fetchArray( + "SELECT table_name FROM information_schema.tables WHERE table_schema = ? AND engine = 'MyISAM'", + array($dbName) + ); + + return $result; + } +} + diff --git a/tests/lib/repair/repairinnodb.php b/tests/lib/repair/repairinnodb.php new file mode 100644 index 00000000000..e7d2442f127 --- /dev/null +++ b/tests/lib/repair/repairinnodb.php @@ -0,0 +1,65 @@ +<?php +/** + * Copyright (c) 2014 Thomas Müller <deepdiver@owncloud.com> + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +/** + * Tests for the converting of MySQL tables to InnoDB engine + * + * @see \OC\Repair\RepairMimeTypes + */ +class TestRepairInnoDB extends PHPUnit_Framework_TestCase { + + /** @var \OC\RepairStep */ + private $repair; + + /** @var \Doctrine\DBAL\Connection */ + private $connection; + + /** @var string */ + private $tableName; + + public function setUp() { + $this->connection = \OC_DB::getConnection(); + if (!$this->connection->getDatabasePlatform() instanceof \Doctrine\DBAL\Platforms\MySqlPlatform) { + $this->markTestSkipped("Test only relevant on MySql"); + } + + $dbPrefix = \OC::$server->getConfig()->getSystemValue("dbtableprefix"); + $this->tableName = uniqid($dbPrefix . "_innodb_test"); + $this->connection->exec("CREATE TABLE $this->tableName(id INT) ENGINE MyISAM"); + + $this->repair = new \OC\Repair\InnoDB(); + } + + public function tearDown() { + $this->connection->getSchemaManager()->dropTable($this->tableName); + } + + public function testInnoDBConvert() { + $result = $this->countMyIsamTables(); + $this->assertEquals(1, $result); + + $this->repair->run(); + + $result = $this->countMyIsamTables(); + $this->assertEquals(0, $result); + } + + /** + * @param $dbName + * @return mixed + */ + private function countMyIsamTables() { + $dbName = \OC::$server->getConfig()->getSystemValue("dbname"); + + $result = $this->connection->fetchColumn( + "SELECT count(*) FROM information_schema.tables WHERE table_schema = ? and table_name = ? AND engine = 'MyISAM'", + array($dbName, $this->tableName) + ); + return $result; + } +} |