From 22cd65b7d89b89ca306db6a08edfef328f2cbeae Mon Sep 17 00:00:00 2001 From: Juan Basso Date: Sun, 1 Apr 2012 00:01:11 -0400 Subject: [PATCH] Added tests in each datasource to test the nested transactions. --- .../Model/Datasource/Database/MysqlTest.php | 38 ++++++++++++++++++- .../Datasource/Database/PostgresTest.php | 35 +++++++++++++++++ .../Model/Datasource/Database/SqliteTest.php | 35 +++++++++++++++++ 3 files changed, 107 insertions(+), 1 deletion(-) diff --git a/lib/Cake/Test/Case/Model/Datasource/Database/MysqlTest.php b/lib/Cake/Test/Case/Model/Datasource/Database/MysqlTest.php index 3024a0607..a91069a60 100644 --- a/lib/Cake/Test/Case/Model/Datasource/Database/MysqlTest.php +++ b/lib/Cake/Test/Case/Model/Datasource/Database/MysqlTest.php @@ -45,7 +45,7 @@ class MysqlTest extends CakeTestCase { public $fixtures = array( 'core.apple', 'core.article', 'core.articles_tag', 'core.attachment', 'core.comment', 'core.sample', 'core.tag', 'core.user', 'core.post', 'core.author', 'core.data_test', - 'core.binary_test' + 'core.binary_test', 'app.address' ); /** @@ -3579,4 +3579,40 @@ class MysqlTest extends CakeTestCase { ->with("TRUNCATE TABLE `$schema`.`tbl_articles`"); $this->Dbo->truncate('articles'); } + +/** + * Test nested transaction + * + * @return void + */ + public function testNestedTransaction() { + $obj = new ReflectionMethod($this->Dbo, '_supportNestedTransaction'); + $obj->setAccessible(true); + $this->skipIf($obj->invoke($this->Dbo) === false, 'The MySQL server do not support nested transaction'); + + $this->loadFixtures('Address'); + $model = ClassRegistry::init('Address'); + $model->hasOne = $model->hasMany = $model->belongsTo = $model->hasAndBelongsToMany = array(); + $model->cacheQueries = false; + $this->Dbo->cacheMethods = false; + + $this->assertTrue($this->Dbo->begin()); + $this->assertNotEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->begin()); + $this->assertTrue($model->delete(1)); + $this->assertEmpty($model->read(null, 1)); + $this->assertTrue($this->Dbo->rollback()); + $this->assertNotEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->begin()); + $this->assertTrue($model->delete(1)); + $this->assertEmpty($model->read(null, 1)); + $this->assertTrue($this->Dbo->commit()); + $this->assertEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->rollback()); + $this->assertNotEmpty($model->read(null, 1)); + } + } diff --git a/lib/Cake/Test/Case/Model/Datasource/Database/PostgresTest.php b/lib/Cake/Test/Case/Model/Datasource/Database/PostgresTest.php index 54b331f48..4a6b7897e 100644 --- a/lib/Cake/Test/Case/Model/Datasource/Database/PostgresTest.php +++ b/lib/Cake/Test/Case/Model/Datasource/Database/PostgresTest.php @@ -909,4 +909,39 @@ class PostgresTest extends CakeTestCase { $this->Dbo->truncate('articles'); } +/** + * Test nested transaction + * + * @return void + */ + public function testNestedTransaction() { + $obj = new ReflectionMethod($this->Dbo, '_supportNestedTransaction'); + $obj->setAccessible(true); + $this->skipIf($obj->invoke($this->Dbo) === false, 'The Postgres server do not support nested transaction'); + + $this->loadFixtures('Article'); + $model = new Article(); + $model->hasOne = $model->hasMany = $model->belongsTo = $model->hasAndBelongsToMany = array(); + $model->cacheQueries = false; + $this->Dbo->cacheMethods = false; + + $this->assertTrue($this->Dbo->begin()); + $this->assertNotEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->begin()); + $this->assertTrue($model->delete(1)); + $this->assertEmpty($model->read(null, 1)); + $this->assertTrue($this->Dbo->rollback()); + $this->assertNotEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->begin()); + $this->assertTrue($model->delete(1)); + $this->assertEmpty($model->read(null, 1)); + $this->assertTrue($this->Dbo->commit()); + $this->assertEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->rollback()); + $this->assertNotEmpty($model->read(null, 1)); + } + } diff --git a/lib/Cake/Test/Case/Model/Datasource/Database/SqliteTest.php b/lib/Cake/Test/Case/Model/Datasource/Database/SqliteTest.php index f53257bff..1e4ed7e46 100644 --- a/lib/Cake/Test/Case/Model/Datasource/Database/SqliteTest.php +++ b/lib/Cake/Test/Case/Model/Datasource/Database/SqliteTest.php @@ -383,4 +383,39 @@ class SqliteTest extends CakeTestCase { $this->assertTrue(Validation::uuid($result['Uuid']['id']), 'Not a uuid'); } +/** + * Test nested transaction + * + * @return void + */ + public function testNestedTransaction() { + $obj = new ReflectionMethod($this->Dbo, '_supportNestedTransaction'); + $obj->setAccessible(true); + $this->skipIf($obj->invoke($this->Dbo) === false, 'The Sqlite version do not support nested transaction'); + + $this->loadFixtures('User'); + $model = new User(); + $model->hasOne = $model->hasMany = $model->belongsTo = $model->hasAndBelongsToMany = array(); + $model->cacheQueries = false; + $this->Dbo->cacheMethods = false; + + $this->assertTrue($this->Dbo->begin()); + $this->assertNotEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->begin()); + $this->assertTrue($model->delete(1)); + $this->assertEmpty($model->read(null, 1)); + $this->assertTrue($this->Dbo->rollback()); + $this->assertNotEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->begin()); + $this->assertTrue($model->delete(1)); + $this->assertEmpty($model->read(null, 1)); + $this->assertTrue($this->Dbo->commit()); + $this->assertEmpty($model->read(null, 1)); + + $this->assertTrue($this->Dbo->rollback()); + $this->assertNotEmpty($model->read(null, 1)); + } + }