Yii2 framework backup
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.
 
 
 
 
 

110 lines
2.9 KiB

<?php
/**
* @link http://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license http://www.yiiframework.com/license/
*/
namespace yiiunit\framework\db;
use yii\db\ActiveQuery;
use yii\db\Query;
trait GetTablesAliasTestTrait
{
/**
* @return Query|ActiveQuery
*/
abstract protected function createQuery();
public function testGetTableNames_isFromArray()
{
$query = $this->createQuery();
$query->from = [
'{{prf}}' => '{{profile}}',
'{{usr}}' => '{{user}}',
'{{a b}}' => '{{c d}}',
];
$tables = $query->getTablesUsedInFrom();
$this->assertEquals([
'{{prf}}' => '{{profile}}',
'{{usr}}' => '{{user}}',
'{{a b}}' => '{{c d}}',
], $tables);
}
public function testGetTableNames_isFromString()
{
$query = $this->createQuery();
$query->from = 'profile AS \'prf\', user "usr", `order`, "customer", "a b" as "c d"';
$tables = $query->getTablesUsedInFrom();
$this->assertEquals([
'{{prf}}' => '{{profile}}',
'{{usr}}' => '{{user}}',
'{{order}}' => '{{order}}',
'{{customer}}' => '{{customer}}',
'{{c d}}' => '{{a b}}',
], $tables);
}
public function testGetTableNames_isFromObject_generateException()
{
$query = $this->createQuery();
$query->from = new \stdClass();
$this->expectException('\yii\base\InvalidConfigException');
$query->getTablesUsedInFrom();
}
public function testGetTablesAlias_isFromString()
{
$query = $this->createQuery();
$query->from = 'profile AS \'prf\', user "usr", service srv, order, [a b] [c d], {{something}} AS myalias';
$tables = $query->getTablesUsedInFrom();
$this->assertEquals([
'{{prf}}' => '{{profile}}',
'{{usr}}' => '{{user}}',
'{{srv}}' => '{{service}}',
'{{order}}' => '{{order}}',
'{{c d}}' => '{{a b}}',
'{{myalias}}' => '{{something}}',
], $tables);
}
/**
* @see https://github.com/yiisoft/yii2/issues/14150
*/
public function testGetTableAliasFromPrefixedTableName()
{
$query = $this->createQuery();
$query->from = '{{%order_item}}';
$tables = $query->getTablesUsedInFrom();
$this->assertEquals([
'{{%order_item}}' => '{{%order_item}}',
], $tables);
}
/**
* @see https://github.com/yiisoft/yii2/issues/14211
*/
public function testGetTableAliasFromTableNameWithDatabase()
{
$query = $this->createQuery();
$query->from = 'tickets.workflows';
$tables = $query->getTablesUsedInFrom();
$this->assertEquals([
'{{tickets.workflows}}' => '{{tickets.workflows}}',
], $tables);
}
}