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