| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage UnitTests | 
					
						
							|  |  |  |  * @since 2011-11-4 | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * Unit tests for MySQLiStatement class | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../util/profiler/CommandProfiler.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../util/profiler/Profiler.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/Db.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/DbDriver.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/DbStatement.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/MySQLiStatement.php'; | 
					
						
							| 
									
										
										
										
											2011-11-25 19:50:41 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../exception/GeneralException.php'; | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | class MySQLiStatementTest extends PHPUnit_Framework_TestCase | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $driver; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $stmt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $testData = array( | 
					
						
							|  |  |  |         array('one' => 11, 'two' => 12), | 
					
						
							|  |  |  |         array('one' => 21, 'two' => 22), | 
					
						
							|  |  |  |         array('one' => 31, 'two' => 32), | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function run(PHPUnit_Framework_TestResult $result = NULL) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setPreserveGlobalState(false); | 
					
						
							|  |  |  |         return parent::run($result); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setUp() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!isset($this->stmt)) { | 
					
						
							|  |  |  |             $this->driver = $this->getMockBuilder('DbDriverMock') | 
					
						
							|  |  |  |                     ->disableOriginalConstructor() | 
					
						
							|  |  |  |                     ->setMethods(array('quote', 'getConnection')) | 
					
						
							|  |  |  |                     ->getMock(); | 
					
						
							|  |  |  |             $this->sql = 'SELECT * :place FROM :place AND :new'; | 
					
						
							|  |  |  |             $this->stmt = new MySQLiStatement($this->driver, $this->sql); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchNoResult() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testDriverExecuteNoResult() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionWrongResultMethod(); | 
					
						
							| 
									
										
										
										
											2011-12-02 12:25:47 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'ERROR'); | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testFetch() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							| 
									
										
										
										
											2011-12-02 17:22:31 +04:00
										 |  |  |         $this->assertSame('OBJECT', $this->stmt->fetch()); | 
					
						
							|  |  |  |         $this->assertSame('ARRAY', $this->stmt->fetch(Db::FETCH_NUM)); | 
					
						
							|  |  |  |         $this->assertSame('ASSOC', $this->stmt->fetch(Db::FETCH_ASSOC)); | 
					
						
							|  |  |  |         $this->assertSame('ARRAY', $this->stmt->fetch(Db::FETCH_BOTH)); | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchObject() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							| 
									
										
										
										
											2011-12-02 17:22:31 +04:00
										 |  |  |         $this->assertSame('OBJECT', $this->stmt->fetchObject()); | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchWithDebug() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							| 
									
										
										
										
											2011-12-02 17:22:31 +04:00
										 |  |  |         $this->assertSame('OBJECT', $this->stmt->fetch()); | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testClose() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertAttributeEquals(null, 'result', $this->stmt); | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							|  |  |  |         $this->assertAttributeNotEquals(null, 'result', $this->stmt); | 
					
						
							|  |  |  |         $this->stmt->close(); | 
					
						
							|  |  |  |         $this->assertAttributeEquals(null, 'result', $this->stmt); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testAffectedRows() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $mysqliMock = $this->getMockBuilder('MysqliDrvr'); | 
					
						
							|  |  |  |         $mysqliMock->affected_rows = 'AFFECTED_ROWS'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('getConnection') | 
					
						
							|  |  |  |                 ->will($this->returnValue($mysqliMock)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-02 17:22:31 +04:00
										 |  |  |         $this->assertSame('AFFECTED_ROWS', $this->stmt->affectedRows()); | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testNumRowsNoResult() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->numRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-11-07 19:55:49 +04:00
										 |  |  |      * @TODO: exception just for code coverage - could not mock mysqli properties | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testNumRows() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-12-01 17:35:13 +04:00
										 |  |  |         $this->markTestSkipped('Unable to execute a method or access a property of an incomplete object.'); | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							|  |  |  |         $this->assertNull($this->stmt->numRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchInvalidMode() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->stmt->execute(array('place' => 'place_val', 'new' => 'new_val')); | 
					
						
							| 
									
										
										
										
											2011-12-02 12:25:47 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->setExpectedException('GeneralException'); | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2011-11-04 13:33:31 +04:00
										 |  |  |         $this->stmt->fetch(324); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function setDriverGetConnectionMethod() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $resultMock = $this->getMockBuilder('mysqli_result') | 
					
						
							|  |  |  |                 ->disableOriginalConstructor() | 
					
						
							|  |  |  |                 ->setMethods(array('fetch_object', 'fetch_array', 'fetch_assoc', 'close')) | 
					
						
							|  |  |  |                 ->setMockClassName('Mysqli_Result_Mock') | 
					
						
							|  |  |  |                 ->getMock(); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('fetch_object') | 
					
						
							|  |  |  |                 ->will($this->returnValue('OBJECT')); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('fetch_array') | 
					
						
							|  |  |  |                 ->will($this->returnValue('ARRAY')); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('fetch_assoc') | 
					
						
							|  |  |  |                 ->will($this->returnValue('ASSOC')); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('close') | 
					
						
							|  |  |  |                 ->will($this->returnValue(TRUE)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mysqliMock = $this->getMock('MysqliDrvr', array('query')); | 
					
						
							|  |  |  |         $mysqliMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('query') | 
					
						
							|  |  |  |                 ->with($this->anything()) | 
					
						
							|  |  |  |                 ->will($this->returnValue($resultMock)); | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('getConnection') | 
					
						
							|  |  |  |                 ->will($this->returnValue($mysqliMock)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function setDriverGetConnectionWrongResultMethod() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $mysqliMock = $this->getMock('MysqliDrvr', array('query')); | 
					
						
							|  |  |  |         $mysqliMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('query') | 
					
						
							|  |  |  |                 ->with($this->anything()) | 
					
						
							|  |  |  |                 ->will($this->returnValue(false)); | 
					
						
							|  |  |  |         $mysqliMock->error = 'ERROR'; | 
					
						
							|  |  |  |         $mysqliMock->errno = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('getConnection') | 
					
						
							|  |  |  |                 ->will($this->returnValue($mysqliMock)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |