TableGeneratorTest.php 1.86 KB
Newer Older
1 2 3 4 5
<?php

namespace Doctrine\Tests\DBAL\Functional;

use Doctrine\DBAL\Id\TableGenerator;
Sergei Morozov's avatar
Sergei Morozov committed
6 7 8 9
use Doctrine\DBAL\Id\TableGeneratorSchemaVisitor;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Tests\DbalFunctionalTestCase;
use Throwable;
10 11 12 13

/**
 * @group DDC-450
 */
Sergei Morozov's avatar
Sergei Morozov committed
14
class TableGeneratorTest extends DbalFunctionalTestCase
15
{
Sergei Morozov's avatar
Sergei Morozov committed
16
    /** @var TableGenerator */
17 18
    private $generator;

19
    protected function setUp()
20 21 22
    {
        parent::setUp();

Sergei Morozov's avatar
Sergei Morozov committed
23
        $platform = $this->connection->getDatabasePlatform();
Sergei Morozov's avatar
Sergei Morozov committed
24
        if ($platform->getName() === 'sqlite') {
25 26 27 28
            $this->markTestSkipped('TableGenerator does not work with SQLite');
        }

        try {
Sergei Morozov's avatar
Sergei Morozov committed
29 30
            $schema  = new Schema();
            $visitor = new TableGeneratorSchemaVisitor();
31 32 33
            $schema->visit($visitor);

            foreach ($schema->toSql($platform) as $sql) {
Sergei Morozov's avatar
Sergei Morozov committed
34
                $this->connection->exec($sql);
35
            }
Sergei Morozov's avatar
Sergei Morozov committed
36
        } catch (Throwable $e) {
37
        }
Sergei Morozov's avatar
Sergei Morozov committed
38
        $this->generator = new TableGenerator($this->connection);
39 40 41 42
    }

    public function testNextVal()
    {
Sergei Morozov's avatar
Sergei Morozov committed
43 44 45
        $id1 = $this->generator->nextValue('tbl1');
        $id2 = $this->generator->nextValue('tbl1');
        $id3 = $this->generator->nextValue('tbl2');
46

Sergei Morozov's avatar
Sergei Morozov committed
47 48 49
        self::assertGreaterThan(0, $id1, 'First id has to be larger than 0');
        self::assertEquals($id1 + 1, $id2, 'Second id is one larger than first one.');
        self::assertEquals($id1, $id3, 'First ids from different tables are equal.');
50 51 52 53
    }

    public function testNextValNotAffectedByOuterTransactions()
    {
Sergei Morozov's avatar
Sergei Morozov committed
54
        $this->connection->beginTransaction();
Sergei Morozov's avatar
Sergei Morozov committed
55
        $id1 = $this->generator->nextValue('tbl1');
Sergei Morozov's avatar
Sergei Morozov committed
56
        $this->connection->rollBack();
Sergei Morozov's avatar
Sergei Morozov committed
57
        $id2 = $this->generator->nextValue('tbl1');
58

Sergei Morozov's avatar
Sergei Morozov committed
59 60
        self::assertGreaterThan(0, $id1, 'First id has to be larger than 0');
        self::assertEquals($id1 + 1, $id2, 'Second id is one larger than first one.');
61 62
    }
}