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.
99 lines
4.5 KiB
99 lines
4.5 KiB
<?php |
|
|
|
namespace yiiunit\framework\db\pgsql; |
|
|
|
use yii\db\Transaction; |
|
|
|
/** |
|
* @group db |
|
* @group pgsql |
|
*/ |
|
class ConnectionTest extends \yiiunit\framework\db\ConnectionTest |
|
{ |
|
protected $driverName = 'pgsql'; |
|
|
|
public function testConnection() |
|
{ |
|
$this->assertTrue(is_object($this->getConnection(true))); |
|
} |
|
|
|
public function testQuoteValue() |
|
{ |
|
$connection = $this->getConnection(false); |
|
$this->assertEquals(123, $connection->quoteValue(123)); |
|
$this->assertEquals("'string'", $connection->quoteValue('string')); |
|
$this->assertEquals("'It''s interesting'", $connection->quoteValue("It's interesting")); |
|
} |
|
|
|
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->setIsolationLevel(Transaction::READ_UNCOMMITTED); |
|
$transaction->commit(); |
|
|
|
$transaction = $connection->beginTransaction(); |
|
$transaction->setIsolationLevel(Transaction::READ_COMMITTED); |
|
$transaction->commit(); |
|
|
|
$transaction = $connection->beginTransaction(); |
|
$transaction->setIsolationLevel(Transaction::REPEATABLE_READ); |
|
$transaction->commit(); |
|
|
|
$transaction = $connection->beginTransaction(); |
|
$transaction->setIsolationLevel(Transaction::SERIALIZABLE); |
|
$transaction->commit(); |
|
|
|
$transaction = $connection->beginTransaction(); |
|
$transaction->setIsolationLevel(Transaction::SERIALIZABLE . ' READ ONLY DEFERRABLE'); |
|
$transaction->commit(); |
|
} |
|
}
|
|
|