Passed
Pull Request — master (#4)
by Alexander
01:47
created

QueryHelperTest   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 25
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 3
c 1
b 0
f 0
lcom 1
cbo 3
dl 0
loc 25
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A testCoalesce() 0 6 1
A testCustomSqlFunction() 0 6 1
A testSingleParam() 0 8 1
1
<?php
2
3
namespace Horat1us\Yii\Tests\Helpers;
4
5
use Horat1us\Yii\Helpers\QueryHelper;
6
use PHPUnit\Framework\TestCase;
7
use yii\db\Expression;
8
9
class QueryHelperTest extends TestCase
10
{
11
    public function testCoalesce()
12
    {
13
        $expression = QueryHelper::coalesce('a', 'b');
14
15
        $this->assertEquals('COALESCE((a), (b))', $expression);
16
    }
17
18
    public function testCustomSqlFunction()
19
    {
20
        $expression = QueryHelper::sqlCall('MIN', 1, 2, new Expression('3'));
21
22
        $this->assertEquals('MIN((1), (2), (3))', $expression);
23
    }
24
25
    public function testSingleParam()
26
    {
27
        $command = 'SELECT CURRENT_DATE';
28
        $function = 'EXISTS';
29
        $expression = QueryHelper::sqlCall($function, $command);
30
31
        $this->assertEquals("{$function}(({$command}))", $expression);
32
    }
33
}