Completed
Push — master ( f2ef3e...a98c98 )
by Bartko
01:49
created

Zend2Test   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 69
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 7

Importance

Changes 0
Metric Value
wmc 5
lcom 1
cbo 7
dl 0
loc 69
rs 10
c 0
b 0
f 0

5 Methods

Rating   Name   Duplication   Size   Complexity  
A tearDown() 0 4 1
A testGetBlankDbSelect() 0 13 1
A testGetDefaultDbSelectMustAlwaysReturnNewInstance() 0 12 1
A testSetDefaultDbSelect() 0 18 1
A getDbAdapterMock() 0 12 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace StefanoTreeTest\Unit\NestedSet\Adapter;
6
7
use Mockery;
8
use StefanoTree\NestedSet\Adapter\Zend2 as NestedSetAdapter;
9
use StefanoTree\NestedSet\Options;
10
use StefanoTreeTest\UnitTestCase;
11
use Zend\Db\Adapter\Adapter as DbAdapter;
12
use Zend\Db\Sql\Select as SqlSelect;
13
14
class Zend2Test extends UnitTestCase
15
{
16
    protected function tearDown()
17
    {
18
        Mockery::close();
19
    }
20
21
    public function testGetBlankDbSelect()
22
    {
23
        $options = new Options(array(
24
            'tableName' => 'tableName',
25
            'idColumnName' => 'id',
26
        ));
27
28
        $dbAdapter = $this->getDbAdapterMock();
29
        $adapter = new NestedSetAdapter($options, $dbAdapter);
30
31
        $this->assertEquals('SELECT "tableName".* FROM "tableName"',
32
            $adapter->getBlankDbSelect()->getSqlString());
33
    }
34
35
    public function testGetDefaultDbSelectMustAlwaysReturnNewInstance()
36
    {
37
        $options = new Options(array(
38
            'tableName' => 'tableName',
39
            'idColumnName' => 'id',
40
        ));
41
42
        $dbAdapter = $this->getDbAdapterMock();
43
        $adapter = new NestedSetAdapter($options, $dbAdapter);
44
45
        $this->assertNotSame($adapter->getDefaultDbSelect(), $adapter->getDefaultDbSelect());
46
    }
47
48
    public function testSetDefaultDbSelect()
49
    {
50
        $options = new Options(array(
51
            'tableName' => 'tableName',
52
            'idColumnName' => 'id',
53
        ));
54
55
        $dbAdapter = $this->getDbAdapterMock();
56
        $adapter = new NestedSetAdapter($options, $dbAdapter);
57
58
        $selectBuilder = function () {
59
            return new SqlSelect('table');
60
        };
61
62
        $adapter->setDbSelectBuilder($selectBuilder);
63
64
        $this->assertEquals($selectBuilder()->getSqlString(), $adapter->getDefaultDbSelect()->getSqlString());
65
    }
66
67
    /**
68
     * @return DbAdapter
69
     */
70
    private function getDbAdapterMock()
71
    {
72
        $dbA = new DbAdapter(array(
73
            'driver' => 'Pdo_Sqlite',
74
            'database' => ':memory:',
75
        ));
76
77
        $dbAdapterMock = Mockery::mock($dbA);
78
        $dbAdapterMock->makePartial();
79
80
        return $dbAdapterMock;
81
    }
82
}
83