You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
4.0 KiB
88 lines
4.0 KiB
<?php |
|
/** |
|
* @link http://www.yiiframework.com/ |
|
* @copyright Copyright (c) 2008 Yii Software LLC |
|
* @license http://www.yiiframework.com/license/ |
|
*/ |
|
|
|
namespace yiiunit\framework\db\oci; |
|
|
|
use yii\db\Transaction; |
|
|
|
/** |
|
* @group db |
|
* @group oci |
|
*/ |
|
class ConnectionTest extends \yiiunit\framework\db\ConnectionTest |
|
{ |
|
protected $driverName = 'oci'; |
|
|
|
public function testSerialize() |
|
{ |
|
$connection = $this->getConnection(false, false); |
|
$connection->open(); |
|
$serialized = serialize($connection); |
|
$unserialized = unserialize($serialized); |
|
$this->assertInstanceOf('yii\db\Connection', $unserialized); |
|
|
|
$this->assertEquals(123, $unserialized->createCommand('SELECT 123 FROM DUAL')->queryScalar()); |
|
} |
|
|
|
public function testQuoteTableName() |
|
{ |
|
$connection = $this->getConnection(false); |
|
$this->assertEquals('"table"', $connection->quoteTableName('table')); |
|
$this->assertEquals('"table"', $connection->quoteTableName('"table"')); |
|
$this->assertEquals('"schema"."table"', $connection->quoteTableName('schema.table')); |
|
$this->assertEquals('"schema"."table"', $connection->quoteTableName('schema."table"')); |
|
$this->assertEquals('"schema"."table"', $connection->quoteTableName('"schema"."table"')); |
|
$this->assertEquals('{{table}}', $connection->quoteTableName('{{table}}')); |
|
$this->assertEquals('(table)', $connection->quoteTableName('(table)')); |
|
} |
|
|
|
public function testQuoteColumnName() |
|
{ |
|
$connection = $this->getConnection(false); |
|
$this->assertEquals('"column"', $connection->quoteColumnName('column')); |
|
$this->assertEquals('"column"', $connection->quoteColumnName('"column"')); |
|
$this->assertEquals('[[column]]', $connection->quoteColumnName('[[column]]')); |
|
$this->assertEquals('{{column}}', $connection->quoteColumnName('{{column}}')); |
|
$this->assertEquals('(column)', $connection->quoteColumnName('(column)')); |
|
|
|
$this->assertEquals('"column"', $connection->quoteSql('[[column]]')); |
|
$this->assertEquals('"column"', $connection->quoteSql('{{column}}')); |
|
} |
|
|
|
public function testQuoteFullColumnName() |
|
{ |
|
$connection = $this->getConnection(false, false); |
|
$this->assertEquals('"table"."column"', $connection->quoteColumnName('table.column')); |
|
$this->assertEquals('"table"."column"', $connection->quoteColumnName('table."column"')); |
|
$this->assertEquals('"table"."column"', $connection->quoteColumnName('"table".column')); |
|
$this->assertEquals('"table"."column"', $connection->quoteColumnName('"table"."column"')); |
|
|
|
$this->assertEquals('[[table.column]]', $connection->quoteColumnName('[[table.column]]')); |
|
$this->assertEquals('{{table}}."column"', $connection->quoteColumnName('{{table}}.column')); |
|
$this->assertEquals('{{table}}."column"', $connection->quoteColumnName('{{table}}."column"')); |
|
$this->assertEquals('{{table}}.[[column]]', $connection->quoteColumnName('{{table}}.[[column]]')); |
|
$this->assertEquals('{{%table}}."column"', $connection->quoteColumnName('{{%table}}.column')); |
|
$this->assertEquals('{{%table}}."column"', $connection->quoteColumnName('{{%table}}."column"')); |
|
|
|
$this->assertEquals('"table"."column"', $connection->quoteSql('[[table.column]]')); |
|
$this->assertEquals('"table"."column"', $connection->quoteSql('{{table}}.[[column]]')); |
|
$this->assertEquals('"table"."column"', $connection->quoteSql('{{table}}."column"')); |
|
$this->assertEquals('"table"."column"', $connection->quoteSql('{{%table}}.[[column]]')); |
|
$this->assertEquals('"table"."column"', $connection->quoteSql('{{%table}}."column"')); |
|
} |
|
|
|
public function testTransactionIsolation() |
|
{ |
|
$connection = $this->getConnection(true); |
|
|
|
$transaction = $connection->beginTransaction(Transaction::READ_COMMITTED); |
|
$transaction->commit(); |
|
|
|
$transaction = $connection->beginTransaction(Transaction::SERIALIZABLE); |
|
$transaction->commit(); |
|
} |
|
}
|
|
|