mirror of
https://github.com/yiisoft/yii2.git
synced 2026-03-08 00:07:23 +01:00
* Add github action for testing oci8 Oracle. * Fix CommandTest::testQueryCache. * Fix tests CommandTest::testBindParamsNonWhere. * Fix test CommandTest::testInsert. * Fix test CommanTest::testInsertExpression. * Fix test CommandTest::testInsertSelectAlias. * Fix test CommandTest::testBindParamValue. * Fix tests CommandTest::testBatchInsertDataTypesLocale. * Fix test CommandTest::testNoTablenameReplacement. * Fix test CommandTest::testCreateTable. * Fix test CommandTest::testsInsertQueryAsColumnValue. * Fix tests CommandTest::testAlterTable. * Fix test CommandTest::testCreateView. * Fix test CommandTest::testTransaction. * Fix test ConnectionTest::testTransactionShortcutCorrect. * Fix test ConnectionTest::testTransactionShortcutCustom. * Fix test ConnectionTest::testEnableQueryLog. * Fix test QueryBuilder::testAddDropDefaultValue. * Fix test QueryTest::testUnion. * Fix test QueryTest::testExpressionInFrom. * Fix test SchemaTest::testFindUniqueIndexes. * Fix test QueryBuilderTest::testGetColumnType. * Fix test ActiveRecordTest::testFind. * Fix test ExistValidatorTest::testExpresionInAttributeColumnName. * Fix test UniqueValidatorTest::testExpressionInAttributeColumnName. * Fix ActiveRecordTest testCastValues(), testDefaultValues. * Fix test UniqueValidatorTest::testValidateAttributeDefault. * Fix test UniqueValidatorTest::testValidateEmptyAttributeInStringField. * Fix test UniqueValidatorTest::testValidateEmptyAttributeInIntField. * Fix test ActiveRecordTest::testBit. * Fix test ActiveRecordTest::testBooleanAttribute. * Fix test ActiveRecordTest::testJoinWithAlias. * Fix test SchemaTest::testColumnSchema. * Fix test CommandTest:: testBatchInsertSQL. * Skip CommandTest::testColumnCase. * Fix test ConnectionTest::testQuoteValue. * Should be fixed tests conditionsProvider in QueryBuilderTest. * Fix ActiveRecordTest.php * Fix test UniqueValidatorTest. * Fix test QueryBuilderTest::testUpsert. * Skip SchemaTest::testCompositeFK.
121 lines
5.3 KiB
PHP
121 lines
5.3 KiB
PHP
<?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\Connection;
|
|
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();
|
|
}
|
|
|
|
/**
|
|
* Note: The READ UNCOMMITTED isolation level allows dirty reads. Oracle Database doesn't use dirty reads, nor does
|
|
* it even allow them.
|
|
*
|
|
* Change Transaction::READ_UNCOMMITTED => Transaction::READ_COMMITTED.
|
|
*/
|
|
public function testTransactionShortcutCustom()
|
|
{
|
|
$connection = $this->getConnection(true);
|
|
|
|
$result = $connection->transaction(static function (Connection $db) {
|
|
$db->createCommand()->insert('profile', ['description' => 'test transaction shortcut'])->execute();
|
|
return true;
|
|
}, Transaction::READ_COMMITTED);
|
|
|
|
$this->assertTrue($result, 'transaction shortcut valid value should be returned from callback');
|
|
|
|
$profilesCount = $connection->createCommand(
|
|
"SELECT COUNT(*) FROM {{profile}} WHERE [[description]] = 'test transaction shortcut'"
|
|
)->queryScalar();
|
|
$this->assertEquals(1, $profilesCount, 'profile should be inserted in transaction shortcut');
|
|
}
|
|
|
|
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"));
|
|
}
|
|
}
|