This repository has been archived by the owner on Jan 8, 2020. It is now read-only.
/
DbSelectTest.php
94 lines (74 loc) · 3.19 KB
/
DbSelectTest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @package Zend_Paginator
*/
namespace ZendTest\Paginator\Adapter;
use Zend\Paginator\Adapter\DbSelect;
use Zend\Db\Sql\Select;
use Zend\Db\Sql\Expression;
/**
* @category Zend
* @package Zend_Paginator
* @subpackage UnitTests
* @group Zend_Paginator
*/
class DbSelectTest extends \PHPUnit_Framework_TestCase
{
/** @var \PHPUnit_Framework_MockObject_MockObject */
protected $mockSelect;
/** @var \PHPUnit_Framework_MockObject_MockObject */
protected $mockStatement;
/** @var \PHPUnit_Framework_MockObject_MockObject */
protected $mockResult;
/** @var \PHPUnit_Framework_MockObject_MockObject */
protected $mockSql;
/** @var DbSelect */
protected $dbSelect;
public function setup()
{
$mockResult = $this->getMock('Zend\Db\Adapter\Driver\ResultInterface');
$this->mockResult = $mockResult;
$mockStatement = $this->getMock('Zend\Db\Adapter\Driver\StatementInterface');
$this->mockStatement = $mockStatement;
$this->mockStatement->expects($this->any())->method('execute')->will($this->returnValue($this->mockResult));
$mockDriver = $this->getMock('Zend\Db\Adapter\Driver\DriverInterface');
$mockDriver->expects($this->any())->method('createStatement')->will($this->returnValue($mockStatement));
$mockPlatform = $this->getMock('Zend\Db\Adapter\Platform\PlatformInterface');
$mockPlatform->expects($this->any())->method('getName')->will($this->returnValue('platform'));
$mockAdapter = $this->getMockForAbstractClass(
'Zend\Db\Adapter\Adapter',
array($mockDriver, $mockPlatform)
);
$mockSql = $this->getMock(
'Zend\Db\Sql\Sql',
array('prepareStatementForSqlObject', 'execute'),
array($mockAdapter)
);
$this->mockSql = $mockSql;
$this->mockSql->expects($this->once())
->method('prepareStatementForSqlObject')
->with($this->isInstanceOf('Zend\Db\Sql\Select'))
->will($this->returnValue($this->mockStatement));
$this->mockSelect = $this->getMock('Zend\Db\Sql\Select');
$this->dbSelect = new DbSelect($this->mockSelect, $mockSql);
}
public function testGetItems()
{
$this->mockSelect->expects($this->once())->method('limit')->with($this->equalTo(10));
$this->mockSelect->expects($this->once())->method('offset')->with($this->equalTo(2));
$items = $this->dbSelect->getItems(2, 10);
$this->assertInstanceOf('Zend\Db\ResultSet\ResultSet', $items);
}
public function testCount()
{
$this->mockResult->expects($this->once())->method('current')->will($this->returnValue(array('c' => 5)));
$this->mockSelect->expects($this->exactly(3))->method('reset'); // called for columns, limit, offset, order
$count = $this->dbSelect->count();
$this->assertEquals(5, $count);
}
}