2006-11-23 15:30:00 +00:00
|
|
|
<?php
|
2006-11-23 23:23:24 +00:00
|
|
|
class Doctrine_Transaction_Firebird_TestCase extends Doctrine_Driver_UnitTestCase {
|
2006-11-23 15:30:00 +00:00
|
|
|
public function __construct() {
|
|
|
|
parent::__construct('firebird');
|
|
|
|
}
|
|
|
|
public function testCreateSavePointExecutesSql() {
|
|
|
|
$this->transaction->createSavePoint('mypoint');
|
|
|
|
|
|
|
|
$this->assertEqual($this->adapter->pop(), 'SAVEPOINT mypoint');
|
|
|
|
}
|
|
|
|
public function testReleaseSavePointExecutesSql() {
|
|
|
|
$this->transaction->releaseSavePoint('mypoint');
|
|
|
|
|
|
|
|
$this->assertEqual($this->adapter->pop(), 'RELEASE SAVEPOINT mypoint');
|
|
|
|
}
|
|
|
|
public function testRollbackSavePointExecutesSql() {
|
|
|
|
$this->transaction->rollbackSavePoint('mypoint');
|
|
|
|
|
|
|
|
$this->assertEqual($this->adapter->pop(), 'ROLLBACK TO SAVEPOINT mypoint');
|
|
|
|
}
|
|
|
|
public function testSetIsolationThrowsExceptionOnUnknownIsolationMode() {
|
|
|
|
try {
|
|
|
|
$this->transaction->setIsolation('unknown');
|
|
|
|
$this->fail();
|
|
|
|
} catch(Doctrine_Transaction_Exception $e) {
|
|
|
|
$this->pass();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function testSetIsolationThrowsExceptionOnUnknownWaitMode() {
|
|
|
|
try {
|
|
|
|
$this->transaction->setIsolation('READ UNCOMMITTED', array('wait' => 'unknown'));
|
|
|
|
$this->fail();
|
|
|
|
} catch(Doctrine_Transaction_Exception $e) {
|
|
|
|
$this->pass();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function testSetIsolationThrowsExceptionOnUnknownReadWriteMode() {
|
|
|
|
try {
|
|
|
|
$this->transaction->setIsolation('READ UNCOMMITTED', array('rw' => 'unknown'));
|
|
|
|
$this->fail();
|
|
|
|
} catch(Doctrine_Transaction_Exception $e) {
|
|
|
|
$this->pass();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function testSetIsolationExecutesSql() {
|
|
|
|
$this->transaction->setIsolation('READ UNCOMMITTED');
|
|
|
|
$this->transaction->setIsolation('READ COMMITTED');
|
|
|
|
$this->transaction->setIsolation('REPEATABLE READ');
|
2006-11-23 23:23:24 +00:00
|
|
|
$this->transaction->setIsolation('SERIALIZABLE');
|
2006-11-23 15:30:00 +00:00
|
|
|
|
2006-11-23 23:23:24 +00:00
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION ISOLATION LEVEL SNAPSHOT TABLE STABILITY');
|
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION ISOLATION LEVEL SNAPSHOT');
|
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION ISOLATION LEVEL READ COMMITTED NO RECORD_VERSION');
|
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION ISOLATION LEVEL READ COMMITTED RECORD_VERSION');
|
2006-11-23 15:30:00 +00:00
|
|
|
}
|
|
|
|
public function testSetIsolationSupportsReadWriteOptions() {
|
|
|
|
$this->transaction->setIsolation('SERIALIZABLE', array('rw' => 'READ ONLY'));
|
|
|
|
|
2006-11-23 23:23:24 +00:00
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION READ ONLY ISOLATION LEVEL SNAPSHOT TABLE STABILITY');
|
2006-11-23 15:30:00 +00:00
|
|
|
|
|
|
|
$this->transaction->setIsolation('SERIALIZABLE', array('rw' => 'READ WRITE'));
|
|
|
|
|
2006-11-23 23:23:24 +00:00
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION READ WRITE ISOLATION LEVEL SNAPSHOT TABLE STABILITY');
|
2006-11-23 15:30:00 +00:00
|
|
|
}
|
|
|
|
public function testSetIsolationSupportsWaitOptions() {
|
|
|
|
$this->transaction->setIsolation('SERIALIZABLE', array('wait' => 'NO WAIT'));
|
|
|
|
|
2006-11-23 23:23:24 +00:00
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION NO WAIT ISOLATION LEVEL SNAPSHOT TABLE STABILITY');
|
2006-11-23 15:30:00 +00:00
|
|
|
|
|
|
|
$this->transaction->setIsolation('SERIALIZABLE', array('wait' => 'WAIT'));
|
|
|
|
|
2006-11-23 23:23:24 +00:00
|
|
|
$this->assertEqual($this->adapter->pop(), 'SET TRANSACTION WAIT ISOLATION LEVEL SNAPSHOT TABLE STABILITY');
|
2006-11-23 15:30:00 +00:00
|
|
|
}
|
|
|
|
}
|