summaryrefslogtreecommitdiffstats
path: root/tests/lib
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2022-03-10 14:04:04 +0100
committerJoas Schilling <coding@schilljs.com>2022-03-10 14:04:04 +0100
commit1970d3dc9ab599e67ad1a0393fc5707ec283cf08 (patch)
tree1b408c0842067f01f51700bd9ca5e856653d79e1 /tests/lib
parentb35253a4c30a7d769559f5e23f04700b6883e05b (diff)
downloadnextcloud-server-1970d3dc9ab599e67ad1a0393fc5707ec283cf08.tar.gz
nextcloud-server-1970d3dc9ab599e67ad1a0393fc5707ec283cf08.zip
Add a test for primary keys
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'tests/lib')
-rw-r--r--tests/lib/DB/MigrationsTest.php44
1 files changed, 43 insertions, 1 deletions
diff --git a/tests/lib/DB/MigrationsTest.php b/tests/lib/DB/MigrationsTest.php
index 507f3d0e228..f22de8c5e6e 100644
--- a/tests/lib/DB/MigrationsTest.php
+++ b/tests/lib/DB/MigrationsTest.php
@@ -246,6 +246,8 @@ class MigrationsTest extends \Test\TestCase {
->method('getName')
->willReturn(\str_repeat('a', 30));
+ $primaryKey = $this->createMock(Index::class);
+
$table->expects($this->once())
->method('getColumns')
->willReturn([$column]);
@@ -257,7 +259,7 @@ class MigrationsTest extends \Test\TestCase {
->willReturn([$foreignKey]);
$table->expects($this->once())
->method('getPrimaryKey')
- ->willReturn(null);
+ ->willReturn($primaryKey);
$schema = $this->createMock(Schema::class);
$schema->expects($this->once())
@@ -607,6 +609,46 @@ class MigrationsTest extends \Test\TestCase {
}
+ public function testEnsureOracleConstraintsNoPrimaryKey() {
+ $this->expectException(\InvalidArgumentException::class);
+
+ $table = $this->createMock(Table::class);
+ $table->expects($this->atLeastOnce())
+ ->method('getName')
+ ->willReturn(\str_repeat('a', 30));
+ $table->expects($this->once())
+ ->method('getColumns')
+ ->willReturn([]);
+ $table->expects($this->once())
+ ->method('getIndexes')
+ ->willReturn([]);
+ $table->expects($this->once())
+ ->method('getForeignKeys')
+ ->willReturn([]);
+ $table->expects($this->once())
+ ->method('getPrimaryKey')
+ ->willReturn(null);
+
+ $schema = $this->createMock(Schema::class);
+ $schema->expects($this->once())
+ ->method('getTables')
+ ->willReturn([$table]);
+ $schema->expects($this->once())
+ ->method('getSequences')
+ ->willReturn([]);
+
+ $sourceSchema = $this->createMock(Schema::class);
+ $sourceSchema->expects($this->any())
+ ->method('getTable')
+ ->willThrowException(new SchemaException());
+ $sourceSchema->expects($this->any())
+ ->method('hasSequence')
+ ->willReturn(false);
+
+ self::invokePrivate($this->migrationService, 'ensureOracleConstraints', [$sourceSchema, $schema, 3]);
+ }
+
+
public function testEnsureOracleConstraintsTooLongSequenceName() {
$this->expectException(\InvalidArgumentException::class);