SchemaDiffTest.php 4.98 KB
Newer Older
1 2 3 4
<?php

namespace Doctrine\Tests\DBAL\Schema;

5
use Doctrine\DBAL\Platforms\AbstractPlatform;
Sergei Morozov's avatar
Sergei Morozov committed
6
use Doctrine\DBAL\Schema\ForeignKeyConstraint;
jeroendedauw's avatar
jeroendedauw committed
7 8 9 10
use Doctrine\DBAL\Schema\SchemaDiff;
use Doctrine\DBAL\Schema\Sequence;
use Doctrine\DBAL\Schema\Table;
use Doctrine\DBAL\Schema\TableDiff;
11
use PHPUnit\Framework\MockObject\MockObject;
Sergei Morozov's avatar
Sergei Morozov committed
12
use PHPUnit\Framework\TestCase;
13

Sergei Morozov's avatar
Sergei Morozov committed
14
class SchemaDiffTest extends TestCase
15
{
16
    public function testSchemaDiffToSql() : void
17
    {
Sergei Morozov's avatar
Sergei Morozov committed
18
        $diff     = $this->createSchemaDiff();
19
        $platform = $this->createPlatform(true);
20 21 22

        $sql = $diff->toSql($platform);

Sergei Morozov's avatar
Sergei Morozov committed
23
        $expected = ['create_schema', 'drop_orphan_fk', 'alter_seq', 'drop_seq', 'create_seq', 'create_table', 'create_foreign_key', 'drop_table', 'alter_table'];
24

25
        self::assertEquals($expected, $sql);
26 27
    }

28
    public function testSchemaDiffToSaveSql() : void
29
    {
Sergei Morozov's avatar
Sergei Morozov committed
30
        $diff     = $this->createSchemaDiff();
31
        $platform = $this->createPlatform(false);
32 33 34

        $sql = $diff->toSaveSql($platform);

Sergei Morozov's avatar
Sergei Morozov committed
35
        $expected = ['create_schema', 'alter_seq', 'create_seq', 'create_table', 'create_foreign_key', 'alter_table'];
36

37
        self::assertEquals($expected, $sql);
38 39
    }

40 41 42 43
    /**
     * @return AbstractPlatform|MockObject
     */
    private function createPlatform(bool $unsafe)
44
    {
45 46
        /** @var AbstractPlatform|MockObject $platform */
        $platform = $this->createMock(AbstractPlatform::class);
47 48 49 50
        $platform->expects($this->exactly(1))
            ->method('getCreateSchemaSQL')
            ->with('foo_ns')
            ->will($this->returnValue('create_schema'));
51 52
        if ($unsafe) {
            $platform->expects($this->exactly(1))
53
                 ->method('getDropSequenceSql')
Sergei Morozov's avatar
Sergei Morozov committed
54
                 ->with($this->isInstanceOf(Sequence::class))
55
                 ->will($this->returnValue('drop_seq'));
56 57 58
        }
        $platform->expects($this->exactly(1))
                 ->method('getAlterSequenceSql')
Sergei Morozov's avatar
Sergei Morozov committed
59
                 ->with($this->isInstanceOf(Sequence::class))
60 61
                 ->will($this->returnValue('alter_seq'));
        $platform->expects($this->exactly(1))
62
                 ->method('getCreateSequenceSql')
Sergei Morozov's avatar
Sergei Morozov committed
63
                 ->with($this->isInstanceOf(Sequence::class))
64
                 ->will($this->returnValue('create_seq'));
65 66
        if ($unsafe) {
            $platform->expects($this->exactly(1))
67
                     ->method('getDropTableSql')
Sergei Morozov's avatar
Sergei Morozov committed
68
                     ->with($this->isInstanceOf(Table::class))
69 70 71 72
                     ->will($this->returnValue('drop_table'));
        }
        $platform->expects($this->exactly(1))
                 ->method('getCreateTableSql')
Sergei Morozov's avatar
Sergei Morozov committed
73
                 ->with($this->isInstanceOf(Table::class))
Sergei Morozov's avatar
Sergei Morozov committed
74
                 ->will($this->returnValue(['create_table']));
75 76
        $platform->expects($this->exactly(1))
                 ->method('getCreateForeignKeySQL')
Sergei Morozov's avatar
Sergei Morozov committed
77
                 ->with($this->isInstanceOf(ForeignKeyConstraint::class))
78
                 ->will($this->returnValue('create_foreign_key'));
79 80
        $platform->expects($this->exactly(1))
                 ->method('getAlterTableSql')
Sergei Morozov's avatar
Sergei Morozov committed
81
                 ->with($this->isInstanceOf(TableDiff::class))
Sergei Morozov's avatar
Sergei Morozov committed
82
                 ->will($this->returnValue(['alter_table']));
83 84
        if ($unsafe) {
            $platform->expects($this->exactly(1))
85
                     ->method('getDropForeignKeySql')
86
                     ->with(
Sergei Morozov's avatar
Sergei Morozov committed
87 88
                         $this->isInstanceOf(ForeignKeyConstraint::class),
                         $this->isInstanceOf(Table::class)
89
                     )
90 91
                     ->will($this->returnValue('drop_orphan_fk'));
        }
92 93 94
        $platform->expects($this->exactly(1))
                ->method('supportsSchemas')
                ->will($this->returnValue(true));
95 96 97
        $platform->expects($this->exactly(1))
                ->method('supportsSequences')
                ->will($this->returnValue(true));
98
        $platform->expects($this->exactly(2))
99 100
                ->method('supportsForeignKeyConstraints')
                ->will($this->returnValue(true));
101

102 103 104
        return $platform;
    }

105
    public function createSchemaDiff() : SchemaDiff
106
    {
Sergei Morozov's avatar
Sergei Morozov committed
107 108
        $diff                              = new SchemaDiff();
        $diff->newNamespaces['foo_ns']     = 'foo_ns';
109
        $diff->removedNamespaces['bar_ns'] = 'bar_ns';
110
        $diff->changedSequences['foo_seq'] = new Sequence('foo_seq');
Sergei Morozov's avatar
Sergei Morozov committed
111
        $diff->newSequences['bar_seq']     = new Sequence('bar_seq');
112
        $diff->removedSequences['baz_seq'] = new Sequence('baz_seq');
Sergei Morozov's avatar
Sergei Morozov committed
113 114 115
        $diff->newTables['foo_table']      = new Table('foo_table');
        $diff->removedTables['bar_table']  = new Table('bar_table');
        $diff->changedTables['baz_table']  = new TableDiff('baz_table');
116
        $diff->newTables['foo_table']->addColumn('foreign_id', 'integer');
Sergei Morozov's avatar
Sergei Morozov committed
117 118
        $diff->newTables['foo_table']->addForeignKeyConstraint('foreign_table', ['foreign_id'], ['id']);
        $fk = new ForeignKeyConstraint(['id'], 'foreign_table', ['id']);
119 120
        $fk->setLocalTable(new Table('local_table'));
        $diff->orphanedForeignKeys[] = $fk;
121

122 123
        return $diff;
    }
124
}