IndexTest.php 6.07 KB
Newer Older
1 2 3 4 5
<?php

namespace Doctrine\Tests\DBAL\Schema;

use Doctrine\DBAL\Schema\Index;
Sergei Morozov's avatar
Sergei Morozov committed
6
use PHPUnit\Framework\TestCase;
7

Sergei Morozov's avatar
Sergei Morozov committed
8
class IndexTest extends TestCase
9
{
10 11 12
    /**
     * @param mixed[] $options
     */
13
    private function createIndex(bool $unique = false, bool $primary = false, array $options = []): Index
14
    {
Sergei Morozov's avatar
Sergei Morozov committed
15
        return new Index('foo', ['bar', 'baz'], $unique, $primary, [], $options);
16 17
    }

18
    public function testCreateIndex(): void
19 20
    {
        $idx = $this->createIndex();
Sergei Morozov's avatar
Sergei Morozov committed
21
        self::assertEquals('foo', $idx->getName());
22
        $columns = $idx->getColumns();
Gabriel Caruso's avatar
Gabriel Caruso committed
23
        self::assertCount(2, $columns);
Sergei Morozov's avatar
Sergei Morozov committed
24
        self::assertEquals(['bar', 'baz'], $columns);
25 26
        self::assertFalse($idx->isUnique());
        self::assertFalse($idx->isPrimary());
27 28
    }

29
    public function testCreatePrimary(): void
30 31
    {
        $idx = $this->createIndex(false, true);
32 33
        self::assertTrue($idx->isUnique());
        self::assertTrue($idx->isPrimary());
34 35
    }

36
    public function testCreateUnique(): void
37 38
    {
        $idx = $this->createIndex(true, false);
39 40
        self::assertTrue($idx->isUnique());
        self::assertFalse($idx->isPrimary());
41
    }
42

43
    public function testFulfilledByUnique(): void
44 45 46 47 48
    {
        $idx1 = $this->createIndex(true, false);
        $idx2 = $this->createIndex(true, false);
        $idx3 = $this->createIndex();

49 50
        self::assertTrue($idx1->isFullfilledBy($idx2));
        self::assertFalse($idx1->isFullfilledBy($idx3));
51 52
    }

53
    public function testFulfilledByPrimary(): void
54 55 56 57 58
    {
        $idx1 = $this->createIndex(true, true);
        $idx2 = $this->createIndex(true, true);
        $idx3 = $this->createIndex(true, false);

59 60
        self::assertTrue($idx1->isFullfilledBy($idx2));
        self::assertFalse($idx1->isFullfilledBy($idx3));
61 62
    }

63
    public function testFulfilledByIndex(): void
64 65 66
    {
        $idx1 = $this->createIndex();
        $idx2 = $this->createIndex();
Sergei Morozov's avatar
Sergei Morozov committed
67
        $pri  = $this->createIndex(true, true);
68 69
        $uniq = $this->createIndex(true);

70 71 72
        self::assertTrue($idx1->isFullfilledBy($idx2));
        self::assertTrue($idx1->isFullfilledBy($pri));
        self::assertTrue($idx1->isFullfilledBy($uniq));
73
    }
74

75
    public function testFulfilledWithPartial(): void
76
    {
Sergei Morozov's avatar
Sergei Morozov committed
77 78 79
        $without = new Index('without', ['col1', 'col2'], true, false, [], []);
        $partial = new Index('partial', ['col1', 'col2'], true, false, [], ['where' => 'col1 IS NULL']);
        $another = new Index('another', ['col1', 'col2'], true, false, [], ['where' => 'col1 IS NULL']);
80

81 82
        self::assertFalse($partial->isFullfilledBy($without));
        self::assertFalse($without->isFullfilledBy($partial));
83

84
        self::assertTrue($partial->isFullfilledBy($partial));
85

86 87
        self::assertTrue($partial->isFullfilledBy($another));
        self::assertTrue($another->isFullfilledBy($partial));
88 89
    }

90
    public function testOverrulesWithPartial(): void
91
    {
Sergei Morozov's avatar
Sergei Morozov committed
92 93 94
        $without = new Index('without', ['col1', 'col2'], true, false, [], []);
        $partial = new Index('partial', ['col1', 'col2'], true, false, [], ['where' => 'col1 IS NULL']);
        $another = new Index('another', ['col1', 'col2'], true, false, [], ['where' => 'col1 IS NULL']);
95

96 97
        self::assertFalse($partial->overrules($without));
        self::assertFalse($without->overrules($partial));
98

99
        self::assertTrue($partial->overrules($partial));
100

101 102
        self::assertTrue($partial->overrules($another));
        self::assertTrue($another->overrules($partial));
103 104
    }

105 106 107 108 109 110 111
    /**
     * @param string[]     $columns
     * @param int[]|null[] $lengths1
     * @param int[]|null[] $lengths2
     *
     * @dataProvider indexLengthProvider
     */
112
    public function testFulfilledWithLength(array $columns, array $lengths1, array $lengths2, bool $expected): void
113 114 115 116 117 118 119 120 121 122 123
    {
        $index1 = new Index('index1', $columns, false, false, [], ['lengths' => $lengths1]);
        $index2 = new Index('index2', $columns, false, false, [], ['lengths' => $lengths2]);

        self::assertSame($expected, $index1->isFullfilledBy($index2));
        self::assertSame($expected, $index2->isFullfilledBy($index1));
    }

    /**
     * @return mixed[][]
     */
124
    public static function indexLengthProvider(): iterable
125 126 127 128 129 130 131 132 133 134
    {
        return [
            'empty' => [['column'], [], [], true],
            'same' => [['column'], [64], [64], true],
            'different' => [['column'], [32], [64], false],
            'sparse-different-positions' => [['column1', 'column2'], [0 => 32], [1 => 32], false],
            'sparse-same-positions' => [['column1', 'column2'], [null, 32], [1 => 32], true],
        ];
    }

135
    public function testFlags(): void
136 137
    {
        $idx1 = $this->createIndex();
138 139
        self::assertFalse($idx1->hasFlag('clustered'));
        self::assertEmpty($idx1->getFlags());
140 141

        $idx1->addFlag('clustered');
142 143
        self::assertTrue($idx1->hasFlag('clustered'));
        self::assertTrue($idx1->hasFlag('CLUSTERED'));
Sergei Morozov's avatar
Sergei Morozov committed
144
        self::assertSame(['clustered'], $idx1->getFlags());
145 146

        $idx1->removeFlag('clustered');
147 148
        self::assertFalse($idx1->hasFlag('clustered'));
        self::assertEmpty($idx1->getFlags());
149
    }
150

151
    public function testIndexQuotes(): void
152
    {
Sergei Morozov's avatar
Sergei Morozov committed
153
        $index = new Index('foo', ['`bar`', '`baz`']);
154

Sergei Morozov's avatar
Sergei Morozov committed
155 156 157
        self::assertTrue($index->spansColumns(['bar', 'baz']));
        self::assertTrue($index->hasColumnAtPosition('bar', 0));
        self::assertTrue($index->hasColumnAtPosition('baz', 1));
158

Sergei Morozov's avatar
Sergei Morozov committed
159 160
        self::assertFalse($index->hasColumnAtPosition('bar', 1));
        self::assertFalse($index->hasColumnAtPosition('baz', 0));
161
    }
162

163
    public function testOptions(): void
164 165
    {
        $idx1 = $this->createIndex();
166 167
        self::assertFalse($idx1->hasOption('where'));
        self::assertEmpty($idx1->getOptions());
168

Sergei Morozov's avatar
Sergei Morozov committed
169
        $idx2 = $this->createIndex(false, false, ['where' => 'name IS NULL']);
170 171 172 173
        self::assertTrue($idx2->hasOption('where'));
        self::assertTrue($idx2->hasOption('WHERE'));
        self::assertSame('name IS NULL', $idx2->getOption('where'));
        self::assertSame('name IS NULL', $idx2->getOption('WHERE'));
Sergei Morozov's avatar
Sergei Morozov committed
174
        self::assertSame(['where' => 'name IS NULL'], $idx2->getOptions());
175
    }
176
}