Skip to content

Commit

Permalink
Merge pull request #5733 from morozov/remove-table-methods
Browse files Browse the repository at this point in the history
Remove Table methods
  • Loading branch information
morozov authored Oct 9, 2022
2 parents 3f47978 + 25a2ccc commit 7e284a6
Show file tree
Hide file tree
Showing 8 changed files with 27 additions and 102 deletions.
8 changes: 8 additions & 0 deletions UPGRADE.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,14 @@ awareness about deprecated code.

# Upgrade to 4.0

## BC BREAK: Removed `Table` methods

The following `Table` methods have been removed:

- `getForeignKeyColumns()`,
- `getPrimaryKeyColumns()`,
- `hasPrimaryKey()`.

## BC BREAK: removed `SchemaException` error code constants

The following `SchemaException` class constants have been removed:
Expand Down
18 changes: 0 additions & 18 deletions psalm.xml.dist
Original file line number Diff line number Diff line change
Expand Up @@ -39,26 +39,8 @@
See https://github.com/doctrine/dbal/pull/4317
-->
<file name="tests/Functional/LegacyAPITest.php"/>
<!--
TODO: remove in 4.0.0
-->
<referencedMethod name="Doctrine\DBAL\Schema\TableDiff::getName"/>
<!--
TODO: remove in 4.0.0
-->
<referencedMethod name="Doctrine\DBAL\Schema\Table::getForeignKeyColumns"/>
<referencedMethod name="Doctrine\DBAL\Schema\Table::getPrimaryKeyColumns"/>
<referencedMethod name="Doctrine\DBAL\Schema\Table::hasPrimaryKey"/>
</errorLevel>
</DeprecatedMethod>
<DeprecatedProperty>
<errorLevel type="suppress">
<!--
TODO: remove in 4.0.0
-->
<referencedProperty name="Doctrine\DBAL\Schema\TableDiff::$name"/>
</errorLevel>
</DeprecatedProperty>
<DocblockTypeContradiction>
<errorLevel type="suppress">
<!--
Expand Down
63 changes: 0 additions & 63 deletions src/Schema/Table.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,19 +14,14 @@
use Doctrine\DBAL\Schema\Exception\InvalidTableName;
use Doctrine\DBAL\Schema\Exception\UniqueConstraintDoesNotExist;
use Doctrine\DBAL\Types\Type;
use Doctrine\Deprecations\Deprecation;

use function array_filter;
use function array_merge;
use function array_values;
use function in_array;
use function is_string;
use function preg_match;
use function sprintf;
use function strtolower;

use const ARRAY_FILTER_USE_KEY;

/**
* Object Representation of a table.
*/
Expand Down Expand Up @@ -460,20 +455,6 @@ public function getColumns(): array
return array_values($this->_columns);
}

/**
* Returns only columns that have specified names
*
* @param string[] $columnNames
*
* @return Column[]
*/
private function filterColumns(array $columnNames, bool $reverse = false): array
{
return array_filter($this->_columns, static function (string $columnName) use ($columnNames, $reverse): bool {
return in_array($columnName, $columnNames, true) !== $reverse;
}, ARRAY_FILTER_USE_KEY);
}

/**
* Returns whether this table has a Column with the given name.
*/
Expand Down Expand Up @@ -512,50 +493,6 @@ public function getPrimaryKey(): ?Index
return null;
}

/**
* Returns the primary key columns.
*
* @deprecated Use {@see getPrimaryKey()} and {@see Index::getColumns()} instead.
*
* @return array<string, Column>
*
* @throws SchemaException
*/
public function getPrimaryKeyColumns(): array
{
Deprecation::trigger(
'doctrine/dbal',
'https://github.com/doctrine/dbal/pull/5731',
'%s is deprecated. Use getPrimaryKey() and Index::getColumns() instead.',
__METHOD__,
);

$primaryKey = $this->getPrimaryKey();

if ($primaryKey === null) {
throw new SchemaException(sprintf('Table "%s" has no primary key.', $this->getName()));
}

return $this->filterColumns($primaryKey->getColumns());
}

/**
* Returns whether this table has a primary key.
*
* @deprecated Use {@see getPrimaryKey()} instead.
*/
public function hasPrimaryKey(): bool
{
Deprecation::trigger(
'doctrine/dbal',
'https://github.com/doctrine/dbal/pull/5731',
'%s is deprecated. Use getPrimaryKey() instead.',
__METHOD__,
);

return $this->_primaryKeyName !== null && $this->hasIndex($this->_primaryKeyName);
}

/**
* Returns whether this table has an Index with the given name.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -56,9 +56,10 @@ public function testAlterPrimaryKeyToAutoIncrementColumn(): void

self::assertTrue($validationTable->hasColumn('new_id'));
self::assertTrue($validationTable->getColumn('new_id')->getAutoincrement());
self::assertTrue($validationTable->hasPrimaryKey());
self::assertCount(1, $validationTable->getPrimaryKeyColumns());
self::assertArrayHasKey('new_id', $validationTable->getPrimaryKeyColumns());

$primaryKey = $validationTable->getPrimaryKey();
self::assertNotNull($primaryKey);
self::assertSame(['new_id'], $primaryKey->getColumns());
}

private function getPlatform(): AbstractPlatform
Expand Down
2 changes: 1 addition & 1 deletion tests/Functional/Platform/PlatformRestrictionsTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,6 @@ public function testMaxIdentifierLengthLimitWithAutoIncrement(): void
$createdTable = $this->connection->createSchemaManager()->introspectTable($tableName);

self::assertTrue($createdTable->hasColumn($columnName));
self::assertTrue($createdTable->hasPrimaryKey());
self::assertNotNull($createdTable->getPrimaryKey());
}
}
13 changes: 6 additions & 7 deletions tests/Functional/Schema/MySQLSchemaManagerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -45,12 +45,11 @@ public function testSwitchPrimaryKeyColumns(): void

$this->schemaManager->alterTable($diff);

$table = $this->schemaManager->introspectTable('switch_primary_key_columns');
$primaryKey = $table->getPrimaryKeyColumns();
$table = $this->schemaManager->introspectTable('switch_primary_key_columns');

self::assertCount(2, $primaryKey);
self::assertArrayHasKey('bar_id', $primaryKey);
self::assertArrayHasKey('foo_id', $primaryKey);
$primaryKey = $table->getPrimaryKey();
self::assertNotNull($primaryKey);
self::assertSame(['bar_id', 'foo_id'], $primaryKey->getColumns());
}

public function testFulltextIndex(): void
Expand Down Expand Up @@ -127,7 +126,7 @@ public function testAlterTableAddPrimaryKey(): void
$table = $this->schemaManager->introspectTable('alter_table_add_pk');

self::assertFalse($table->hasIndex('idx_id'));
self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());
}

public function testDropPrimaryKeyWithAutoincrementColumn(): void
Expand All @@ -151,7 +150,7 @@ public function testDropPrimaryKeyWithAutoincrementColumn(): void

$table = $this->schemaManager->introspectTable('drop_primary_key');

self::assertFalse($table->hasPrimaryKey());
self::assertNull($table->getPrimaryKey());
self::assertFalse($table->getColumn('id')->getAutoincrement());
}

Expand Down
2 changes: 0 additions & 2 deletions tests/Functional/Schema/OracleSchemaManagerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,6 @@ public function testListTableDetailsWithDifferentIdentifierQuotingRequirements()

self::assertTrue($onlinePrimaryTable->hasColumn('"Id"'));
self::assertSame('"Id"', $onlinePrimaryTable->getColumn('"Id"')->getQuotedName($platform));
self::assertTrue($onlinePrimaryTable->hasPrimaryKey());

$onlinePrimaryTablePrimaryKey = $onlinePrimaryTable->getPrimaryKey();
self::assertNotNull($onlinePrimaryTablePrimaryKey);
Expand Down Expand Up @@ -156,7 +155,6 @@ public function testListTableDetailsWithDifferentIdentifierQuotingRequirements()
// Foreign table assertions
self::assertTrue($onlineForeignTable->hasColumn('id'));
self::assertSame('ID', $onlineForeignTable->getColumn('id')->getQuotedName($platform));
self::assertTrue($onlineForeignTable->hasPrimaryKey());

$onlineForeignTablePrimaryKey = $onlineForeignTable->getPrimaryKey();
self::assertNotNull($onlineForeignTablePrimaryKey);
Expand Down
16 changes: 8 additions & 8 deletions tests/Schema/TableTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -469,7 +469,7 @@ public function testPrimaryKeyOverrulingUniqueIndexDoesNotDropUniqueIndex(): voi
// Table should only contain both the primary key table index and the unique one, even though it was overruled
self::assertCount(2, $indexes);

self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());
self::assertTrue($table->hasIndex('idx_unique'));
}

Expand Down Expand Up @@ -561,12 +561,12 @@ public function testTableHasPrimaryKey(): void
{
$table = new Table('test');

self::assertFalse($table->hasPrimaryKey());
self::assertNull($table->getPrimaryKey());

$table->addColumn('foo', 'integer');
$table->setPrimaryKey(['foo']);

self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());
}

public function testAddIndexWithQuotedColumns(): void
Expand Down Expand Up @@ -614,10 +614,10 @@ public function testDropPrimaryKey(): void
$table->addColumn('id', 'integer');
$table->setPrimaryKey(['id']);

self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());

$table->dropPrimaryKey();
self::assertFalse($table->hasPrimaryKey());
self::assertNull($table->getPrimaryKey());
}

public function testRenameIndex(): void
Expand All @@ -636,7 +636,7 @@ public function testRenameIndex(): void
self::assertSame($table, $table->renameIndex('idx', 'idx_new'));
self::assertSame($table, $table->renameIndex('uniq', 'uniq_new'));

self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());
self::assertTrue($table->hasIndex('pk_new'));
self::assertTrue($table->hasIndex('idx_new'));
self::assertTrue($table->hasIndex('uniq_new'));
Expand All @@ -658,7 +658,7 @@ public function testRenameIndex(): void
self::assertSame($table, $table->renameIndex('idx_new', null));
self::assertSame($table, $table->renameIndex('uniq_new', null));

self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());
self::assertTrue($table->hasIndex('primary'));
self::assertTrue($table->hasIndex('IDX_D87F7E0C8C736521'));
self::assertTrue($table->hasIndex('UNIQ_D87F7E0C76FF8CAA78240498'));
Expand All @@ -683,7 +683,7 @@ public function testRenameIndex(): void
self::assertSame($table, $table->renameIndex('IDX_D87F7E0C8C736521', 'idx_D87F7E0C8C736521'));
self::assertSame($table, $table->renameIndex('UNIQ_D87F7E0C76FF8CAA78240498', 'uniq_D87F7E0C76FF8CAA78240498'));

self::assertTrue($table->hasPrimaryKey());
self::assertNotNull($table->getPrimaryKey());
self::assertTrue($table->hasIndex('primary'));
self::assertTrue($table->hasIndex('IDX_D87F7E0C8C736521'));
self::assertTrue($table->hasIndex('UNIQ_D87F7E0C76FF8CAA78240498'));
Expand Down

0 comments on commit 7e284a6

Please sign in to comment.