From 3b7f8be171a844f40d4db6de8552a2d78f154a35 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Merlet?= Date: Fri, 16 Jul 2021 19:27:28 +0200 Subject: [PATCH] Remove deprecated Comparator::compare() The method has been deprecated and scheduled for removal since https://github.com/doctrine/dbal/pull/4707. --- UPGRADE.md | 10 + phpstan.neon.dist | 8 - psalm.xml.dist | 7 - src/Schema/Comparator.php | 32 +--- ...imaryKeyWithNewAutoIncrementColumnTest.php | 2 +- tests/Schema/ComparatorTest.php | 175 ++++++++---------- 6 files changed, 89 insertions(+), 145 deletions(-) diff --git a/UPGRADE.md b/UPGRADE.md index 18927edfa0f..9a3f7408a0f 100644 --- a/UPGRADE.md +++ b/UPGRADE.md @@ -8,6 +8,16 @@ awareness about deprecated code. # Upgrade to 4.0 +## Removed static keyword from `Comparator::compareSchemas($fromSchema, $toSchema)` signature + +The method `Comparator::compareSchemas($fromSchema, $toSchema)` cannot be called +statically anymore. + +## Removed `Comparator::compare($fromSchema, $toSchema)` + +The method `Comparator::compare($fromSchema, $toSchema)` has been removed, use +`Comparator::compareSchemas($fromSchema, $toSchema)` instead. + ## Removed `TableGenerator` component The `TableGenerator` component has been removed. diff --git a/phpstan.neon.dist b/phpstan.neon.dist index 69a860a80cf..6ee2a1cdb00 100644 --- a/phpstan.neon.dist +++ b/phpstan.neon.dist @@ -125,14 +125,6 @@ parameters: paths: - %currentWorkingDirectory%/src/Platforms/AbstractPlatform.php - # See https://github.com/doctrine/dbal/pull/4707 - # TODO: remove in 4.0.0 - - - message: '~^Dynamic call to static method Doctrine\\DBAL\\Schema\\Comparator::compareSchemas\(\)\.$~' - paths: - - %currentWorkingDirectory%/src/Schema/AbstractSchemaManager.php - - %currentWorkingDirectory%/src/Schema/Comparator.php - - %currentWorkingDirectory%/src/Schema/Schema.php includes: - vendor/phpstan/phpstan-phpunit/extension.neon - vendor/phpstan/phpstan-phpunit/rules.neon diff --git a/psalm.xml.dist b/psalm.xml.dist index 7fbdb676373..4279343d99d 100644 --- a/psalm.xml.dist +++ b/psalm.xml.dist @@ -60,13 +60,6 @@ --> - - - - diff --git a/src/Schema/Comparator.php b/src/Schema/Comparator.php index e5ed353d521..c20ab0dba19 100644 --- a/src/Schema/Comparator.php +++ b/src/Schema/Comparator.php @@ -5,7 +5,6 @@ namespace Doctrine\DBAL\Schema; use Doctrine\DBAL\Types; -use Doctrine\Deprecations\Deprecation; use function array_intersect_key; use function array_key_exists; @@ -26,13 +25,10 @@ class Comparator /** * Returns a SchemaDiff object containing the differences between the schemas $fromSchema and $toSchema. * - * This method should be called non-statically since it will be declared as non-static in the next major release. - * * @throws SchemaException */ - public static function compareSchemas(Schema $fromSchema, Schema $toSchema): SchemaDiff + public function compareSchemas(Schema $fromSchema, Schema $toSchema): SchemaDiff { - $comparator = new self(); $diff = new SchemaDiff(); $diff->fromSchema = $fromSchema; @@ -59,7 +55,7 @@ public static function compareSchemas(Schema $fromSchema, Schema $toSchema): Sch if (! $fromSchema->hasTable($tableName)) { $diff->newTables[$tableName] = $toSchema->getTable($tableName); } else { - $tableDifferences = $comparator->diffTable( + $tableDifferences = $this->diffTable( $fromSchema->getTable($tableName), $toSchema->getTable($tableName) ); @@ -120,18 +116,18 @@ public static function compareSchemas(Schema $fromSchema, Schema $toSchema): Sch foreach ($toSchema->getSequences() as $sequence) { $sequenceName = $sequence->getShortestName($toSchema->getName()); if (! $fromSchema->hasSequence($sequenceName)) { - if (! $comparator->isAutoIncrementSequenceInSchema($fromSchema, $sequence)) { + if (! $this->isAutoIncrementSequenceInSchema($fromSchema, $sequence)) { $diff->newSequences[] = $sequence; } } else { - if ($comparator->diffSequence($sequence, $fromSchema->getSequence($sequenceName))) { + if ($this->diffSequence($sequence, $fromSchema->getSequence($sequenceName))) { $diff->changedSequences[] = $toSchema->getSequence($sequenceName); } } } foreach ($fromSchema->getSequences() as $sequence) { - if ($comparator->isAutoIncrementSequenceInSchema($toSchema, $sequence)) { + if ($this->isAutoIncrementSequenceInSchema($toSchema, $sequence)) { continue; } @@ -147,24 +143,6 @@ public static function compareSchemas(Schema $fromSchema, Schema $toSchema): Sch return $diff; } - /** - * @deprecated Use non-static call to {@link compareSchemas()} instead. - * - * @return SchemaDiff - * - * @throws SchemaException - */ - public function compare(Schema $fromSchema, Schema $toSchema) - { - Deprecation::trigger( - 'doctrine/dbal', - 'https://github.com/doctrine/dbal/pull/4707', - 'Method compare() is deprecated. Use a non-static call to compareSchemas() instead.' - ); - - return $this->compareSchemas($fromSchema, $toSchema); - } - private function isAutoIncrementSequenceInSchema(Schema $schema, Sequence $sequence): bool { foreach ($schema->getTables() as $table) { diff --git a/tests/Functional/Platform/NewPrimaryKeyWithNewAutoIncrementColumnTest.php b/tests/Functional/Platform/NewPrimaryKeyWithNewAutoIncrementColumnTest.php index 0b4104a0de5..287731972db 100644 --- a/tests/Functional/Platform/NewPrimaryKeyWithNewAutoIncrementColumnTest.php +++ b/tests/Functional/Platform/NewPrimaryKeyWithNewAutoIncrementColumnTest.php @@ -49,7 +49,7 @@ public function testAlterPrimaryKeyToAutoIncrementColumn(): void $newTable->dropPrimaryKey(); $newTable->setPrimaryKey(['new_id']); - $diff = (new Comparator())->compare($schema, $newSchema); + $diff = (new Comparator())->compareSchemas($schema, $newSchema); foreach ($diff->toSql($this->getPlatform()) as $sql) { $this->connection->executeStatement($sql); diff --git a/tests/Schema/ComparatorTest.php b/tests/Schema/ComparatorTest.php index 0e0f7717972..98455094a58 100644 --- a/tests/Schema/ComparatorTest.php +++ b/tests/Schema/ComparatorTest.php @@ -23,6 +23,14 @@ class ComparatorTest extends TestCase { + /** @var Comparator */ + private $comparator; + + protected function setUp(): void + { + $this->comparator = new Comparator(); + } + public function testCompareSame1(): void { $schema1 = new Schema([ @@ -44,7 +52,7 @@ public function testCompareSame1(): void $expected = new SchemaDiff(); $expected->fromSchema = $schema1; - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareSame2(): void @@ -70,7 +78,7 @@ public function testCompareSame2(): void $expected = new SchemaDiff(); $expected->fromSchema = $schema1; - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareMissingTable(): void @@ -85,7 +93,7 @@ public function testCompareMissingTable(): void $expected = new SchemaDiff([], [], ['bugdb' => $table], $schema1); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareNewTable(): void @@ -100,7 +108,7 @@ public function testCompareNewTable(): void $expected = new SchemaDiff(['bugdb' => $table], [], [], $schema1); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareOnlyAutoincrementChanged(): void @@ -108,8 +116,7 @@ public function testCompareOnlyAutoincrementChanged(): void $column1 = new Column('foo', Type::getType('integer'), ['autoincrement' => true]); $column2 = new Column('foo', Type::getType('integer'), ['autoincrement' => false]); - $comparator = new Comparator(); - $changedProperties = $comparator->diffColumn($column1, $column2); + $changedProperties = $this->comparator->diffColumn($column1, $column2); self::assertEquals(['autoincrement'], $changedProperties); } @@ -149,7 +156,7 @@ public function testCompareMissingField(): void $expected->fromSchema = $schema1; $expected->changedTables['bugdb']->fromTable = $schema1->getTable('bugdb'); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareNewField(): void @@ -186,7 +193,7 @@ public function testCompareNewField(): void $expected->fromSchema = $schema1; $expected->changedTables['bugdb']->fromTable = $schema1->getTable('bugdb'); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareChangedColumnsChangeType(): void @@ -194,9 +201,8 @@ public function testCompareChangedColumnsChangeType(): void $column1 = new Column('charcolumn1', Type::getType('string')); $column2 = new Column('charcolumn1', Type::getType('integer')); - $c = new Comparator(); - self::assertEquals(['type'], $c->diffColumn($column1, $column2)); - self::assertEquals([], $c->diffColumn($column1, $column1)); + self::assertEquals(['type'], $this->comparator->diffColumn($column1, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column1)); } public function testCompareColumnsMultipleTypeInstances(): void @@ -208,8 +214,7 @@ public function testCompareColumnsMultipleTypeInstances(): void $column1 = new Column('integercolumn1', $integerType1); $column2 = new Column('integercolumn1', $integerType2); - $c = new Comparator(); - self::assertEquals([], $c->diffColumn($column1, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column2)); } public function testCompareColumnsOverriddenType(): void @@ -225,8 +230,7 @@ public function testCompareColumnsOverriddenType(): void $column1 = new Column('integercolumn1', $integerType); $column2 = new Column('integercolumn1', $overriddenStringType); - $c = new Comparator(); - self::assertEquals([], $c->diffColumn($column1, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column2)); } public function testCompareChangedColumnsChangeCustomSchemaOption(): void @@ -240,9 +244,8 @@ public function testCompareChangedColumnsChangeCustomSchemaOption(): void $column1->setCustomSchemaOption('foo1', 'bar1'); $column2->setCustomSchemaOption('foo2', 'bar2'); - $c = new Comparator(); - self::assertEquals(['foo1', 'foo2'], $c->diffColumn($column1, $column2)); - self::assertEquals([], $c->diffColumn($column1, $column1)); + self::assertEquals(['foo1', 'foo2'], $this->comparator->diffColumn($column1, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column1)); } public function testCompareChangeColumnsMultipleNewColumnsRename(): void @@ -254,7 +257,7 @@ public function testCompareChangeColumnsMultipleNewColumnsRename(): void $tableB->addColumn('new_datecolumn1', 'datetime'); $tableB->addColumn('new_datecolumn2', 'datetime'); - $tableDiff = (new Comparator())->diffTable($tableA, $tableB); + $tableDiff = $this->comparator->diffTable($tableA, $tableB); self::assertNotNull($tableDiff); self::assertCount(1, $tableDiff->renamedColumns); @@ -316,7 +319,7 @@ public function testCompareRemovedIndex(): void $expected->fromSchema = $schema1; $expected->changedTables['bugdb']->fromTable = $schema1->getTable('bugdb'); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareNewIndex(): void @@ -368,7 +371,7 @@ public function testCompareNewIndex(): void $expected->fromSchema = $schema1; $expected->changedTables['bugdb']->fromTable = $schema1->getTable('bugdb'); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareChangedIndex(): void @@ -431,7 +434,7 @@ public function testCompareChangedIndex(): void $expected->fromSchema = $schema1; $expected->changedTables['bugdb']->fromTable = $schema1->getTable('bugdb'); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareChangedIndexFieldPositions(): void @@ -479,7 +482,7 @@ public function testCompareChangedIndexFieldPositions(): void $expected->fromSchema = $schema1; $expected->changedTables['bugdb']->fromTable = $schema1->getTable('bugdb'); - self::assertEquals($expected, Comparator::compareSchemas($schema1, $schema2)); + self::assertEquals($expected, $this->comparator->compareSchemas($schema1, $schema2)); } public function testCompareSequences(): void @@ -488,10 +491,8 @@ public function testCompareSequences(): void $seq2 = new Sequence('foo', 1, 2); $seq3 = new Sequence('foo', 2, 1); - $c = new Comparator(); - - self::assertTrue($c->diffSequence($seq1, $seq2)); - self::assertTrue($c->diffSequence($seq1, $seq3)); + self::assertTrue($this->comparator->diffSequence($seq1, $seq2)); + self::assertTrue($this->comparator->diffSequence($seq1, $seq3)); } public function testRemovedSequence(): void @@ -501,8 +502,7 @@ public function testRemovedSequence(): void $schema2 = new Schema(); - $c = new Comparator(); - $diffSchema = $c->compare($schema1, $schema2); + $diffSchema = $this->comparator->compareSchemas($schema1, $schema2); self::assertCount(1, $diffSchema->removedSequences); self::assertSame($seq, $diffSchema->removedSequences[0]); @@ -515,8 +515,7 @@ public function testAddedSequence(): void $schema2 = new Schema(); $seq = $schema2->createSequence('foo'); - $c = new Comparator(); - $diffSchema = $c->compare($schema1, $schema2); + $diffSchema = $this->comparator->compareSchemas($schema1, $schema2); self::assertCount(1, $diffSchema->newSequences); self::assertSame($seq, $diffSchema->newSequences[0]); @@ -534,8 +533,7 @@ public function testTableAddForeignKey(): void $table2->addColumn('fk', 'integer'); $table2->addForeignKeyConstraint($tableForeign, ['fk'], ['id']); - $c = new Comparator(); - $tableDiff = $c->diffTable($table1, $table2); + $tableDiff = $this->comparator->diffTable($table1, $table2); self::assertInstanceOf(TableDiff::class, $tableDiff); self::assertCount(1, $tableDiff->addedForeignKeys); @@ -553,8 +551,7 @@ public function testTableRemoveForeignKey(): void $table2->addColumn('fk', 'integer'); $table2->addForeignKeyConstraint($tableForeign, ['fk'], ['id']); - $c = new Comparator(); - $tableDiff = $c->diffTable($table2, $table1); + $tableDiff = $this->comparator->diffTable($table2, $table1); self::assertInstanceOf(TableDiff::class, $tableDiff); self::assertCount(1, $tableDiff->removedForeignKeys); @@ -573,8 +570,7 @@ public function testTableUpdateForeignKey(): void $table2->addColumn('fk', 'integer'); $table2->addForeignKeyConstraint($tableForeign, ['fk'], ['id'], ['onUpdate' => 'CASCADE']); - $c = new Comparator(); - $tableDiff = $c->diffTable($table1, $table2); + $tableDiff = $this->comparator->diffTable($table1, $table2); self::assertInstanceOf(TableDiff::class, $tableDiff); self::assertCount(1, $tableDiff->changedForeignKeys); @@ -596,8 +592,7 @@ public function testMovedForeignKeyForeignTable(): void $table2->addColumn('fk', 'integer'); $table2->addForeignKeyConstraint($tableForeign2, ['fk'], ['id']); - $c = new Comparator(); - $tableDiff = $c->diffTable($table1, $table2); + $tableDiff = $this->comparator->diffTable($table1, $table2); self::assertInstanceOf(TableDiff::class, $tableDiff); self::assertCount(1, $tableDiff->changedForeignKeys); @@ -617,8 +612,7 @@ public function testTablesCaseInsensitive(): void $schemaB->createTable('Baz'); $schemaB->createTable('old'); - $c = new Comparator(); - $diff = $c->compare($schemaA, $schemaB); + $diff = $this->comparator->compareSchemas($schemaA, $schemaB); $this->assertSchemaTableChangeCount($diff, 1, 0, 1); } @@ -637,8 +631,7 @@ public function testSequencesCaseInsensitive(): void $schemaB->createSequence('baz'); $schemaB->createSequence('old'); - $c = new Comparator(); - $diff = $c->compare($schemaA, $schemaB); + $diff = $this->comparator->compareSchemas($schemaA, $schemaB); $this->assertSchemaSequenceChangeCount($diff, 1, 0, 1); } @@ -651,8 +644,7 @@ public function testCompareColumnCompareCaseInsensitive(): void $tableB = new Table('foo'); $tableB->addColumn('ID', 'integer'); - $c = new Comparator(); - $tableDiff = $c->diffTable($tableA, $tableB); + $tableDiff = $this->comparator->diffTable($tableA, $tableB); self::assertNull($tableDiff); } @@ -667,14 +659,13 @@ public function testCompareIndexBasedOnPropertiesNotName(): void $tableB->addColumn('ID', 'integer'); $tableB->addIndex(['id'], 'bar_foo_idx'); - $c = new Comparator(); $tableDiff = new TableDiff('foo'); $tableDiff->fromTable = $tableA; $tableDiff->renamedIndexes['foo_bar_idx'] = new Index('bar_foo_idx', ['id']); self::assertEquals( $tableDiff, - $c->diffTable($tableA, $tableB) + $this->comparator->diffTable($tableA, $tableB) ); } @@ -688,8 +679,7 @@ public function testCompareForeignKeyBasedOnPropertiesNotName(): void $tableB->addColumn('ID', 'integer'); $tableB->addForeignKeyConstraint('bar', ['id'], ['id'], [], 'bar_constraint'); - $c = new Comparator(); - $tableDiff = $c->diffTable($tableA, $tableB); + $tableDiff = $this->comparator->diffTable($tableA, $tableB); self::assertNull($tableDiff); } @@ -699,8 +689,7 @@ public function testCompareForeignKeyRestrictNoActionAreTheSame(): void $fk1 = new ForeignKeyConstraint(['foo'], 'bar', ['baz'], 'fk1', ['onDelete' => 'NO ACTION']); $fk2 = new ForeignKeyConstraint(['foo'], 'bar', ['baz'], 'fk1', ['onDelete' => 'RESTRICT']); - $c = new Comparator(); - self::assertFalse($c->diffForeignKey($fk1, $fk2)); + self::assertFalse($this->comparator->diffForeignKey($fk1, $fk2)); } public function testCompareForeignKeyNamesUnqualifiedAsNoSchemaInformationIsAvailable(): void @@ -708,8 +697,7 @@ public function testCompareForeignKeyNamesUnqualifiedAsNoSchemaInformationIsAvai $fk1 = new ForeignKeyConstraint(['foo'], 'foo.bar', ['baz'], 'fk1'); $fk2 = new ForeignKeyConstraint(['foo'], 'baz.bar', ['baz'], 'fk1'); - $c = new Comparator(); - self::assertFalse($c->diffForeignKey($fk1, $fk2)); + self::assertFalse($this->comparator->diffForeignKey($fk1, $fk2)); } public function testDetectRenameColumn(): void @@ -720,7 +708,7 @@ public function testDetectRenameColumn(): void $tableB = new Table('foo'); $tableB->addColumn('bar', 'integer'); - $tableDiff = (new Comparator())->diffTable($tableA, $tableB); + $tableDiff = $this->comparator->diffTable($tableA, $tableB); self::assertNotNull($tableDiff); self::assertCount(0, $tableDiff->addedColumns); @@ -743,7 +731,7 @@ public function testDetectRenameColumnAmbiguous(): void $tableB = new Table('foo'); $tableB->addColumn('baz', 'integer'); - $tableDiff = (new Comparator())->diffTable($tableA, $tableB); + $tableDiff = $this->comparator->diffTable($tableA, $tableB); self::assertNotNull($tableDiff); self::assertCount(1, $tableDiff->addedColumns); @@ -765,7 +753,7 @@ public function testDetectRenameIndex(): void $table2->addIndex(['foo'], 'idx_bar'); - $tableDiff = (new Comparator())->diffTable($table1, $table2); + $tableDiff = $this->comparator->diffTable($table1, $table2); self::assertNotNull($tableDiff); self::assertCount(0, $tableDiff->addedIndexes); @@ -791,7 +779,7 @@ public function testDetectRenameIndexAmbiguous(): void $table2->addIndex(['foo'], 'idx_baz'); - $tableDiff = (new Comparator())->diffTable($table1, $table2); + $tableDiff = $this->comparator->diffTable($table1, $table2); self::assertNotNull($tableDiff); self::assertCount(1, $tableDiff->addedIndexes); @@ -810,8 +798,7 @@ public function testDetectChangeIdentifierType(): void $tableB = new Table('foo'); $tableB->addColumn('id', 'integer', ['autoincrement' => true]); - $c = new Comparator(); - $tableDiff = $c->diffTable($tableA, $tableB); + $tableDiff = $this->comparator->diffTable($tableA, $tableB); self::assertInstanceOf(TableDiff::class, $tableDiff); self::assertArrayHasKey('id', $tableDiff->changedColumns); @@ -832,8 +819,7 @@ public function testDiff(): void $newtable->addColumn('logged_in_at', 'datetime'); $newtable->setPrimaryKey(['id']); - $c = new Comparator(); - $tableDiff = $c->diffTable($table, $newtable); + $tableDiff = $this->comparator->diffTable($table, $newtable); self::assertInstanceOf(TableDiff::class, $tableDiff); self::assertEquals(['twitterid', 'displayname'], array_keys($tableDiff->renamedColumns)); @@ -849,8 +835,7 @@ public function testChangedSequence(): void $schemaNew = clone $schema; $schemaNew->getSequence('baz')->setAllocationSize(20); - $c = new Comparator(); - $diff = $c->compare($schema, $schemaNew); + $diff = $this->comparator->compareSchemas($schema, $schemaNew); self::assertSame($diff->changedSequences[0], $schemaNew->getSequence('baz')); } @@ -865,8 +850,7 @@ public function testDiffDecimalWithNullPrecision(): void $column2 = new Column('foo', Type::getType('decimal')); - $c = new Comparator(); - self::assertEquals([], $c->diffColumn($column, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column, $column2)); } public function testFqnSchemaComparison(): void @@ -883,7 +867,7 @@ public function testFqnSchemaComparison(): void $expected = new SchemaDiff(); $expected->fromSchema = $oldSchema; - self::assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema)); + self::assertEquals($expected, $this->comparator->compareSchemas($oldSchema, $newSchema)); } public function testNamespacesComparison(): void @@ -904,7 +888,7 @@ public function testNamespacesComparison(): void $expected->fromSchema = $oldSchema; $expected->newNamespaces = ['bar' => 'bar', 'baz' => 'baz']; - $diff = Comparator::compareSchemas($oldSchema, $newSchema); + $diff = $this->comparator->compareSchemas($oldSchema, $newSchema); self::assertEquals(['bar' => 'bar', 'baz' => 'baz'], $diff->newNamespaces); self::assertCount(2, $diff->newTables); @@ -924,7 +908,7 @@ public function testFqnSchemaComparisonDifferentSchemaNameButSameTableNoDiff(): $expected = new SchemaDiff(); $expected->fromSchema = $oldSchema; - self::assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema)); + self::assertEquals($expected, $this->comparator->compareSchemas($oldSchema, $newSchema)); } public function testFqnSchemaComparisonNoSchemaSame(): void @@ -940,7 +924,7 @@ public function testFqnSchemaComparisonNoSchemaSame(): void $expected = new SchemaDiff(); $expected->fromSchema = $oldSchema; - self::assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema)); + self::assertEquals($expected, $this->comparator->compareSchemas($oldSchema, $newSchema)); } public function testAutoIncrementSequences(): void @@ -956,8 +940,7 @@ public function testAutoIncrementSequences(): void $table->addColumn('id', 'integer', ['autoincrement' => true]); $table->setPrimaryKey(['id']); - $c = new Comparator(); - $diff = $c->compare($oldSchema, $newSchema); + $diff = $this->comparator->compareSchemas($oldSchema, $newSchema); self::assertCount(0, $diff->removedSequences); } @@ -978,8 +961,7 @@ public function testAutoIncrementNoSequences(): void $table->setPrimaryKey(['id']); $newSchema->createSequence('foo_id_seq'); - $c = new Comparator(); - $diff = $c->compare($oldSchema, $newSchema); + $diff = $this->comparator->compareSchemas($oldSchema, $newSchema); self::assertCount(0, $diff->newSequences); } @@ -1016,8 +998,7 @@ public function testAvoidMultipleDropForeignKey(): void $tableC = $newSchema->createTable('table_c'); $tableC->addColumn('id', 'integer'); - $comparator = new Comparator(); - $schemaDiff = $comparator->compare($oldSchema, $newSchema); + $schemaDiff = $this->comparator->compareSchemas($oldSchema, $newSchema); self::assertCount(1, $schemaDiff->changedTables['table_c']->removedForeignKeys); self::assertCount(1, $schemaDiff->orphanedForeignKeys); @@ -1045,7 +1026,7 @@ public function testCompareChangedColumn(): void $columnDiff->fromColumn = $tableFoo->getColumn('id'); $columnDiff->changedProperties = ['type']; - self::assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema)); + self::assertEquals($expected, $this->comparator->compareSchemas($oldSchema, $newSchema)); } public function testCompareChangedBinaryColumn(): void @@ -1070,7 +1051,7 @@ public function testCompareChangedBinaryColumn(): void $columnDiff->fromColumn = $tableFoo->getColumn('id'); $columnDiff->changedProperties = ['length', 'fixed']; - self::assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema)); + self::assertEquals($expected, $this->comparator->compareSchemas($oldSchema, $newSchema)); } public function testCompareQuotedAndUnquotedForeignKeyColumns(): void @@ -1078,8 +1059,7 @@ public function testCompareQuotedAndUnquotedForeignKeyColumns(): void $fk1 = new ForeignKeyConstraint(['foo'], 'bar', ['baz'], 'fk1', ['onDelete' => 'NO ACTION']); $fk2 = new ForeignKeyConstraint(['`foo`'], 'bar', ['`baz`'], 'fk1', ['onDelete' => 'NO ACTION']); - $comparator = new Comparator(); - $diff = $comparator->diffForeignKey($fk1, $fk2); + $diff = $this->comparator->diffForeignKey($fk1, $fk2); self::assertFalse($diff); } @@ -1131,14 +1111,12 @@ public function testDiffColumnPlatformOptions(): void $column4 = new Column('foo', Type::getType('string')); - $comparator = new Comparator(); - - self::assertEquals([], $comparator->diffColumn($column1, $column2)); - self::assertEquals([], $comparator->diffColumn($column2, $column1)); - self::assertEquals(['bar'], $comparator->diffColumn($column1, $column3)); - self::assertEquals(['bar'], $comparator->diffColumn($column3, $column1)); - self::assertEquals([], $comparator->diffColumn($column1, $column4)); - self::assertEquals([], $comparator->diffColumn($column4, $column1)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column2, $column1)); + self::assertEquals(['bar'], $this->comparator->diffColumn($column1, $column3)); + self::assertEquals(['bar'], $this->comparator->diffColumn($column3, $column1)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column4)); + self::assertEquals([], $this->comparator->diffColumn($column4, $column1)); } public function testComplexDiffColumn(): void @@ -1152,15 +1130,12 @@ public function testComplexDiffColumn(): void 'platformOptions' => ['foo' => 'bar'], ]); - $comparator = new Comparator(); - - self::assertEquals([], $comparator->diffColumn($column1, $column2)); - self::assertEquals([], $comparator->diffColumn($column2, $column1)); + self::assertEquals([], $this->comparator->diffColumn($column1, $column2)); + self::assertEquals([], $this->comparator->diffColumn($column2, $column1)); } public function testComparesNamespaces(): void { - $comparator = new Comparator(); $fromSchema = $this->getMockBuilder(Schema::class) ->onlyMethods(['getNamespaces', 'hasNamespace']) ->getMock(); @@ -1189,13 +1164,11 @@ public function testComparesNamespaces(): void $expected->newNamespaces = ['baz' => 'baz']; $expected->removedNamespaces = ['foo' => 'foo']; - self::assertEquals($expected, $comparator->compare($fromSchema, $toSchema)); + self::assertEquals($expected, $this->comparator->compareSchemas($fromSchema, $toSchema)); } public function testCompareGuidColumns(): void { - $comparator = new Comparator(); - $column1 = new Column('foo', Type::getType('guid'), ['comment' => 'GUID 1']); $column2 = new Column( 'foo', @@ -1203,8 +1176,8 @@ public function testCompareGuidColumns(): void ['notnull' => false, 'length' => 36, 'fixed' => true, 'default' => 'NEWID()', 'comment' => 'GUID 2.'] ); - self::assertEquals(['notnull', 'default', 'comment'], $comparator->diffColumn($column1, $column2)); - self::assertEquals(['notnull', 'default', 'comment'], $comparator->diffColumn($column2, $column1)); + self::assertEquals(['notnull', 'default', 'comment'], $this->comparator->diffColumn($column1, $column2)); + self::assertEquals(['notnull', 'default', 'comment'], $this->comparator->diffColumn($column2, $column1)); } /** @@ -1215,15 +1188,13 @@ public function testCompareColumnComments(string $comment1, string $comment2, bo $column1 = new Column('foo', Type::getType('integer'), ['comment' => $comment1]); $column2 = new Column('foo', Type::getType('integer'), ['comment' => $comment2]); - $comparator = new Comparator(); - $expectedDiff = $equals ? [] : ['comment']; - $actualDiff = $comparator->diffColumn($column1, $column2); + $actualDiff = $this->comparator->diffColumn($column1, $column2); self::assertSame($expectedDiff, $actualDiff); - $actualDiff = $comparator->diffColumn($column2, $column1); + $actualDiff = $this->comparator->diffColumn($column2, $column1); self::assertSame($expectedDiff, $actualDiff); } @@ -1292,7 +1263,7 @@ public function testForeignKeyRemovalWithRenamedLocalColumn(): void ] ), ]); - $actual = Comparator::compareSchemas($fromSchema, $toSchema); + $actual = $this->comparator->compareSchemas($fromSchema, $toSchema); self::assertArrayHasKey('table2', $actual->changedTables); self::assertCount(1, $actual->orphanedForeignKeys);