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")); } }