DBAL202Test.php 1.38 KB
Newer Older
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
<?php

namespace Doctrine\Tests\DBAL\Functional\Ticket;

/**
 * @group DBAL-202
 */
class DBAL202Test extends \Doctrine\Tests\DbalFunctionalTestCase
{
    protected function setUp()
    {
        parent::setUp();

        if ($this->_conn->getDatabasePlatform()->getName() != 'oracle') {
            $this->markTestSkipped('OCI8 only test');
        }

        if ($this->_conn->getSchemaManager()->tablesExist('DBAL202')) {
            $this->_conn->executeQuery('DELETE FROM DBAL202');
        } else {
            $table = new \Doctrine\DBAL\Schema\Table('DBAL202');
            $table->addColumn('id', 'integer');
            $table->setPrimaryKey(array('id'));

            $this->_conn->getSchemaManager()->createTable($table);
        }
    }

    public function testStatementRollback()
    {
        $stmt = $this->_conn->prepare('INSERT INTO DBAL202 VALUES (8)');
        $this->_conn->beginTransaction();
        $stmt->execute();
        $this->_conn->rollback();

        $this->assertEquals(0, $this->_conn->query('SELECT COUNT(1) FROM DBAL202')->fetchColumn());
    }

    public function testStatementCommit()
    {
        $stmt = $this->_conn->prepare('INSERT INTO DBAL202 VALUES (8)');
        $this->_conn->beginTransaction();
        $stmt->execute();
        $this->_conn->commit();

        $this->assertEquals(1, $this->_conn->query('SELECT COUNT(1) FROM DBAL202')->fetchColumn());
    }
}