| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage UnitTests | 
					
						
							|  |  |  |  * @since 2011-11-15 | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * 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/MongoStatement.php'; | 
					
						
							| 
									
										
										
										
											2011-12-06 14:05:18 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../exception/GeneralException.php'; | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | class MongoStatementTest extends PHPUnit_Framework_TestCase | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $driver; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $stmt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $request; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     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('getConnection')) | 
					
						
							|  |  |  |                     ->getMock(); | 
					
						
							|  |  |  |             $this->request = $this->getMockBuilder('MongoDbCommandMock') | 
					
						
							|  |  |  |                     ->disableOriginalConstructor() | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |                     ->setMethods(array('execute', 'bindParam', 'getInsertId')) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |                     ->getMock(); | 
					
						
							|  |  |  |             $this->stmt = new MongoStatement($this->driver, $this->request); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testAffectedNumRowsNoResult() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->affectedRows()); | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->numRows()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array())); | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->affectedRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testAffectedNumRows() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |                 ->expects($this->once()) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('n' => 20, 'ok' => 1))); | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->assertEquals(20, $this->stmt->affectedRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testGetInsertId() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->request = $this->getMockBuilder('InsertMongoCommand') | 
					
						
							|  |  |  |                 ->disableOriginalConstructor() | 
					
						
							|  |  |  |                 ->setMethods(array('execute', 'bindParam', 'getInsertId')) | 
					
						
							|  |  |  |                 ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('n' => 20, 'ok' => 1))); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('getInsertId') | 
					
						
							|  |  |  |                 ->will($this->returnValue('4b0rrs')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt = new MongoStatement($this->driver, $this->request); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->assertEquals('4b0rrs', $this->stmt->getInsertId()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testExecute() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestExecuteMethod(); | 
					
						
							|  |  |  |         $this->assertTrue($this->stmt->execute()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testExecuteNoResult() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(false)); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'MongoDB request error.'); | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testExecuteNoConnection() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('getConnection') | 
					
						
							|  |  |  |                 ->will($this->returnValue(false)); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'No connection to MongoDB server.'); | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testExecuteWithDebug() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestExecuteMethod(); | 
					
						
							|  |  |  |         $this->assertTrue($this->stmt->execute()); | 
					
						
							|  |  |  |         $this->assertEquals(10, $this->stmt->numRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testBindParam() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('bindParam') | 
					
						
							|  |  |  |                 ->will($this->returnValue(true)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestExecuteMethod(); | 
					
						
							|  |  |  |         $this->assertTrue($this->stmt->execute(array('one' => 'two'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertAttributeNotEquals(null, 'result', $this->stmt); | 
					
						
							|  |  |  |         $this->stmt->close(); | 
					
						
							|  |  |  |         $this->assertAttributeEquals(null, 'result', $this->stmt); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFetch() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestForFetch(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $result = $this->stmt->fetch(); | 
					
						
							|  |  |  |         $this->assertEquals('prev', $result->next); | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchWithInitialArray() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchAssocFromCursor() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestForFetch(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $result = $this->stmt->fetch(Db::FETCH_ASSOC); | 
					
						
							|  |  |  |         $this->assertEquals('prev', $result['next']); | 
					
						
							|  |  |  |         $this->assertEquals(array(), $this->stmt->fetch(Db::FETCH_ASSOC)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchAssocFromArray() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $result = $this->stmt->fetch(Db::FETCH_ASSOC); | 
					
						
							|  |  |  |         $this->assertEquals('val', $result['some']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFetchWrongMode() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertFalse($this->stmt->fetch()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'Invalid fetch mode "222" specified'); | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |         $this->stmt->fetch(222); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testSkipOrderLimit() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestForFetch(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->assertInstanceOf('MongoStatement', $this->stmt->order(array('id' => 1))); | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |         $this->assertInstanceOf('MongoStatement', $this->stmt->limit(10)); | 
					
						
							|  |  |  |         $this->assertInstanceOf('MongoStatement', $this->stmt->skip(1)); | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->fetch(); | 
					
						
							|  |  |  |         $this->stmt->fetch(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2012-02-06 18:12:23 +04:00
										 |  |  |     public function testCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod()->setRequestForFetch(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->assertSame(10, $this->stmt->count()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->fetch(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testCountException() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							|  |  |  |         $this->setExpectedException('GeneralException', 'MongoStatement error. Impossible count result of opened cursor'); | 
					
						
							|  |  |  |         $this->stmt->count(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |     public function testOrderException() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'MongoStatement error. Impossible order results of opened cursor'); | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |         $this->stmt->order(array('id' => 1)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testSkipException() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'MongoStatement error. Impossible skip results of opened cursor'); | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |         $this->stmt->skip(array('id' => 1)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testLimitException() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!defined('DEBUG')) { | 
					
						
							|  |  |  |             define('DEBUG', true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->setDriverGetConnectionMethod(); | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->once()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('some' => 'val'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->stmt->execute(); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'MongoStatement error. Impossible limit results of opened cursor'); | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |         $this->stmt->limit(array('id' => 1)); | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private function setDriverGetConnectionMethod() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $mongoMock = $this->getMock('Mongo'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('getConnection') | 
					
						
							|  |  |  |                 ->will($this->returnValue($mongoMock)); | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setRequestExecuteMethod() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $resultMock = $this->getMockBuilder('MongoCursor') | 
					
						
							|  |  |  |                 ->setMethods(array('count')) | 
					
						
							|  |  |  |                 ->disableOriginalConstructor() | 
					
						
							|  |  |  |                 ->getMock(); | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('count') | 
					
						
							|  |  |  |                 ->will($this->returnValue(10)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue($resultMock)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |     public function setRequestForFetch() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $resultMock = $this->getMockBuilder('MongoCursor') | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |                 ->setMethods(array('count', 'getNext', 'limit', 'sort', 'skip')) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |                 ->disableOriginalConstructor() | 
					
						
							|  |  |  |                 ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |                 ->method('limit'); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('sort'); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('skip'); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:07:01 +04:00
										 |  |  |                 ->method('count') | 
					
						
							|  |  |  |                 ->will($this->returnValue(10)); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->at(0)) | 
					
						
							|  |  |  |                 ->method('getNext') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array('next' => 'prev', '_id' => 10))); | 
					
						
							|  |  |  |         $resultMock | 
					
						
							|  |  |  |                 ->expects($this->at(1)) | 
					
						
							|  |  |  |                 ->method('getNext') | 
					
						
							|  |  |  |                 ->will($this->returnValue(array())); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->request | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->will($this->returnValue($resultMock)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |