1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
<?php
declare(strict_types=1);
namespace Doctrine\DBAL\Tests\Schema;
use Doctrine\DBAL\Schema\Exception\InvalidUniqueConstraintDefinition;
use Doctrine\DBAL\Schema\Name\UnqualifiedName;
use Doctrine\DBAL\Schema\UniqueConstraint;
use PHPUnit\Framework\TestCase;
class UniqueConstraintEditorTest extends TestCase
{
public function testEmptyColumnNames(): void
{
$this->expectException(InvalidUniqueConstraintDefinition::class);
UniqueConstraint::editor()
->create();
}
public function testSetUnquotedName(): void
{
$constraint = UniqueConstraint::editor()
->setUnquotedName('uq_id')
->setColumnNames($this->createColumnName())
->create();
self::assertEquals(
UnqualifiedName::unquoted('uq_id'),
$constraint->getObjectName(),
);
}
public function testSetQuotedName(): void
{
$constraint = UniqueConstraint::editor()
->setQuotedName('uq_id')
->setColumnNames($this->createColumnName())
->create();
self::assertEquals(
UnqualifiedName::quoted('uq_id'),
$constraint->getObjectName(),
);
}
public function testSetUnquotedColumnNames(): void
{
$constraint = UniqueConstraint::editor()
->setUnquotedColumnNames('account_id', 'user_id')
->create();
self::assertEquals([
UnqualifiedName::unquoted('account_id'),
UnqualifiedName::unquoted('user_id'),
], $constraint->getColumnNames());
}
public function testSetQuotedColumnNames(): void
{
$constraint = UniqueConstraint::editor()
->setQuotedColumnNames('account_id', 'user_id')
->create();
self::assertEquals([
UnqualifiedName::quoted('account_id'),
UnqualifiedName::quoted('user_id'),
], $constraint->getColumnNames());
}
public function testSetIsClustered(): void
{
$editor = UniqueConstraint::editor()
->setUnquotedColumnNames('user_id');
$constraint = $editor->create();
self::assertFalse($constraint->isClustered());
$constraint = $editor
->setIsClustered(true)
->create();
self::assertTrue($constraint->isClustered());
}
private function createColumnName(): UnqualifiedName
{
return UnqualifiedName::unquoted('id');
}
}
|