Passed
Push — main ( d95b4b...96e631 )
by Sammy
01:51
created

SelectFromTest   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 62
Duplicated Lines 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 30
dl 0
loc 62
rs 10
c 2
b 0
f 0
wmc 6

6 Methods

Rating   Name   Duplication   Size   Complexity  
A testName() 0 4 1
A testConstructor() 0 9 1
A testAddRaw() 0 6 1
A testAddString() 0 6 1
A testAddArray() 0 19 1
A testAll() 0 6 1
1
<?php
2
use PHPUnit\Framework\TestCase;
3
use HexMakina\Crudites\Grammar\Clause\SelectFrom;
4
5
class SelectFromTest extends TestCase
6
{
7
    public function testConstructor()
8
    {
9
        $selectFrom = new SelectFrom('users');
10
        $this->assertEquals('SELECT * FROM `users`', (string)$selectFrom);
11
12
        $selectFrom = new SelectFrom('users', 'u');
13
        $this->assertEquals('users', $selectFrom->table());
14
        $this->assertEquals('u', $selectFrom->alias());
15
        $this->assertEquals('SELECT * FROM `users` `u`', (string)$selectFrom);
16
    }
17
18
    public function testName()
19
    {
20
        $selectFrom = new SelectFrom('users');
21
        $this->assertEquals('SELECT FROM', $selectFrom->name());
22
    }
23
24
    public function testAll()
25
    {
26
        $selectFrom = new SelectFrom('users', 'u');
27
        $selectFrom->all();
28
29
        $this->assertEquals('SELECT * FROM `users` `u`', (string)$selectFrom);
30
    }
31
32
    public function testAddRaw()
33
    {
34
        $selectFrom = new SelectFrom('users', 'u');
35
        $selectFrom->addRaw('COUNT(*)');
36
37
        $this->assertEquals('SELECT COUNT(*) FROM `users` `u`', (string)$selectFrom);
38
    }
39
40
    public function testAddString()
41
    {
42
        $selectFrom = new SelectFrom('users', 'u');
43
        $selectFrom->add('id');
44
45
        $this->assertEquals('SELECT id FROM `users` `u`', (string)$selectFrom);
46
    }
47
48
    public function testAddArray()
49
    {
50
        $selectFrom = new SelectFrom('users', 'u');
51
        $selectFrom->add(['id']);
52
        $selectFrom->add(['name']);
53
54
        $this->assertEquals('SELECT `id`,`name` FROM `users` `u`', (string)$selectFrom);
55
56
        $selectFrom = new SelectFrom('users', 'u');
57
        $selectFrom->add(['id']);
58
        $selectFrom->add(['u', 'name']);
59
60
        $this->assertEquals('SELECT `id`,`u`.`name` FROM `users` `u`', (string)$selectFrom);
61
62
                $selectFrom = new SelectFrom('users');
63
        $selectFrom->add(['id']);
64
        $selectFrom->add(['users', 'name']);
65
66
        $this->assertEquals('SELECT `id`,`users`.`name` FROM `users`', (string)$selectFrom);
67
    }
68
}