summaryrefslogtreecommitdiffstats
path: root/tests/lib/DB/MigrationsTest.php
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2017-06-09 16:45:12 +0200
committerMorris Jobke <hey@morrisjobke.de>2017-07-05 13:02:16 +0200
commit4e5cd1efea7c522ebd763dd3b96eb5f8c0e8407b (patch)
treea184e5b30726048e278f504ebfaa08986a716235 /tests/lib/DB/MigrationsTest.php
parent7a3d83d63038e5db0af790b827b73ec7335a6961 (diff)
downloadnextcloud-server-4e5cd1efea7c522ebd763dd3b96eb5f8c0e8407b.tar.gz
nextcloud-server-4e5cd1efea7c522ebd763dd3b96eb5f8c0e8407b.zip
Fix tests of CodeChecker and MigrationService
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'tests/lib/DB/MigrationsTest.php')
-rw-r--r--tests/lib/DB/MigrationsTest.php90
1 files changed, 69 insertions, 21 deletions
diff --git a/tests/lib/DB/MigrationsTest.php b/tests/lib/DB/MigrationsTest.php
index fbb54bf9a1b..a255cd1b596 100644
--- a/tests/lib/DB/MigrationsTest.php
+++ b/tests/lib/DB/MigrationsTest.php
@@ -13,7 +13,9 @@ namespace Test\DB;
use Doctrine\DBAL\Schema\Schema;
use OC\DB\Connection;
use OC\DB\MigrationService;
+use OC\DB\SchemaWrapper;
use OCP\IDBConnection;
+use OCP\Migration\IMigrationStep;
use OCP\Migration\ISchemaMigration;
use OCP\Migration\ISqlMigration;
@@ -39,8 +41,8 @@ class MigrationsTest extends \Test\TestCase {
public function testGetters() {
$this->assertEquals('testing', $this->migrationService->getApp());
- $this->assertEquals(\OC::$SERVERROOT . '/apps/testing/appinfo/Migrations', $this->migrationService->getMigrationsDirectory());
- $this->assertEquals('OCA\testing\Migrations', $this->migrationService->getMigrationsNamespace());
+ $this->assertEquals(\OC::$SERVERROOT . '/apps/testing/lib/Migration', $this->migrationService->getMigrationsDirectory());
+ $this->assertEquals('OCA\Testing\Migration', $this->migrationService->getMigrationsNamespace());
$this->assertEquals('test_oc_migrations', $this->migrationService->getMigrationsTableName());
}
@@ -84,36 +86,88 @@ class MigrationsTest extends \Test\TestCase {
$this->migrationService->executeStep('20170130180000');
}
- public function testExecuteStepWithSchemaMigrationStep() {
+ public function testExecuteStepWithSchemaChange() {
$schema = $this->createMock(Schema::class);
- $this->db->expects($this->any())->method('createSchema')->willReturn($schema);
+ $this->db->expects($this->any())
+ ->method('createSchema')
+ ->willReturn($schema);
+
+ $this->db->expects($this->once())
+ ->method('migrateToSchema');
+
+ $schemaResult = $this->createMock(SchemaWrapper::class);
+ $schemaResult->expects($this->once())
+ ->method('getWrappedSchema')
+ ->willReturn($this->createMock(Schema::class));
+
+ $step = $this->createMock(IMigrationStep::class);
+ $step->expects($this->at(0))
+ ->method('preSchemaChange');
+ $step->expects($this->at(1))
+ ->method('changeSchema')
+ ->willReturn($schemaResult);
+ $step->expects($this->at(2))
+ ->method('postSchemaChange');
- $step = $this->createMock(ISchemaMigration::class);
- $step->expects($this->once())->method('changeSchema');
$this->migrationService = $this->getMockBuilder(MigrationService::class)
->setMethods(['createInstance'])
->setConstructorArgs(['testing', $this->db])
->getMock();
- $this->migrationService->expects($this->any())->method('createInstance')->with('20170130180000')->willReturn($step);
+
+ $this->migrationService->expects($this->any())
+ ->method('createInstance')
+ ->with('20170130180000')
+ ->willReturn($step);
$this->migrationService->executeStep('20170130180000');
}
- public function testExecuteStepWithSqlMigrationStep() {
+ public function testExecuteStepWithoutSchemaChange() {
- $this->db->expects($this->exactly(3))->method('executeQuery')->withConsecutive(['1'], ['2'], ['3']);
+ $schema = $this->createMock(Schema::class);
+ $this->db->expects($this->any())
+ ->method('createSchema')
+ ->willReturn($schema);
+
+ $this->db->expects($this->never())
+ ->method('migrateToSchema');
+
+ $step = $this->createMock(IMigrationStep::class);
+ $step->expects($this->at(0))
+ ->method('preSchemaChange');
+ $step->expects($this->at(1))
+ ->method('changeSchema')
+ ->willReturn(null);
+ $step->expects($this->at(2))
+ ->method('postSchemaChange');
- $step = $this->createMock(ISqlMigration::class);
- $step->expects($this->once())->method('sql')->willReturn(['1', '2', '3']);
$this->migrationService = $this->getMockBuilder(MigrationService::class)
->setMethods(['createInstance'])
->setConstructorArgs(['testing', $this->db])
->getMock();
- $this->migrationService->expects($this->any())->method('createInstance')->with('20170130180000')->willReturn($step);
+
+ $this->migrationService->expects($this->any())
+ ->method('createInstance')
+ ->with('20170130180000')
+ ->willReturn($step);
$this->migrationService->executeStep('20170130180000');
}
- public function testGetMigration() {
+ public function dataGetMigration() {
+ return [
+ ['current', '20170130180001'],
+ ['prev', '20170130180000'],
+ ['next', '20170130180002'],
+ ['latest', '20170130180003'],
+ ];
+ }
+
+ /**
+ * @dataProvider dataGetMigration
+ * @param string $alias
+ * @param string $expected
+ */
+ public function testGetMigration($alias, $expected) {
$this->migrationService = $this->getMockBuilder(MigrationService::class)
->setMethods(['getMigratedVersions', 'findMigrations'])
->setConstructorArgs(['testing', $this->db])
@@ -129,14 +183,8 @@ class MigrationsTest extends \Test\TestCase {
['20170130180000', '20170130180001', '20170130180002', '20170130180003'],
$this->migrationService->getAvailableVersions());
- $migration = $this->migrationService->getMigration('current');
- $this->assertEquals('20170130180001', $migration);
- $migration = $this->migrationService->getMigration('prev');
- $this->assertEquals('20170130180000', $migration);
- $migration = $this->migrationService->getMigration('next');
- $this->assertEquals('20170130180002', $migration);
- $migration = $this->migrationService->getMigration('latest');
- $this->assertEquals('20170130180003', $migration);
+ $migration = $this->migrationService->getMigration($alias);
+ $this->assertEquals($expected, $migration);
}
public function testMigrate() {