| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage UnitTests | 
					
						
							|  |  |  |  * @since 2011-11-10 | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * Unit tests for MongoDriver class | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../model/Db.php'; | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../model/DbDriver.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/NoSqlDbDriver.php'; | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../model/MongoDbCommand.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/DbStatement.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/MongoStatement.php'; | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../model/MongoDriver.php'; | 
					
						
							| 
									
										
										
										
											2011-12-06 14:05:18 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../exception/GeneralException.php'; | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | class MongoDriverTest extends PHPUnit_Framework_TestCase | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $conf = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setUp() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->conf = array( | 
					
						
							|  |  |  |             'hostname' => 'localhost', | 
					
						
							|  |  |  |             'database' => 'test', | 
					
						
							|  |  |  |             'username' => 'test', | 
					
						
							|  |  |  |             'password' => '1234', | 
					
						
							|  |  |  |             'port' => 27017 | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $data = array( | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'name' => 'bread', | 
					
						
							|  |  |  |                 'price' => 3.2, | 
					
						
							|  |  |  |                 'quantity' => 10 | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'name' => 'eggs', | 
					
						
							|  |  |  |                 'price' => 2.1, | 
					
						
							|  |  |  |                 'quantity' => 20 | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'name' => 'fish', | 
					
						
							|  |  |  |                 'price' => 13.2, | 
					
						
							|  |  |  |                 'quantity' => 2 | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'name' => 'milk', | 
					
						
							|  |  |  |                 'price' => 3.8, | 
					
						
							|  |  |  |                 'quantity' => 1 | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'name' => 'eggs', | 
					
						
							|  |  |  |                 'price' => 2.3, | 
					
						
							|  |  |  |                 'quantity' => 5 | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         $connection = new Mongo('mongodb://' . $this->conf['hostname'] . ':' . $this->conf['port']); | 
					
						
							|  |  |  |         $db = $connection->selectDB($this->conf['database']); | 
					
						
							|  |  |  |         $db->authenticate($this->conf['username'], $this->conf['password']); | 
					
						
							|  |  |  |         $collection = 'items'; | 
					
						
							|  |  |  |         $db->dropCollection($collection); | 
					
						
							|  |  |  |         $collection = $db->selectCollection($collection); | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  |         foreach ($data as $document) { | 
					
						
							|  |  |  |             $collection->insert($document); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     public function testGetConnectionNoHostname() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         unset($this->conf['hostname']); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'Configuration must have a "hostname"'); | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     public function testGetConnectionWrongPassword() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->conf['password'] = 'nopass'; | 
					
						
							|  |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							| 
									
										
										
										
											2011-12-06 16:22:04 +04:00
										 |  |  |         $this->setExpectedException('MongoConnectionException', 'Couldn\'t authenticate with database'); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $this->assertInstanceOf('MongoDB', $mongo->getConnection()); | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     public function testGetConnection() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertFalse($mongo->isConnected()); | 
					
						
							|  |  |  |         $this->assertInstanceOf('Mongo', $mongo->getConnection()); | 
					
						
							|  |  |  |         $this->assertTrue($mongo->isConnected()); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $mongo->getConnection(); | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |         $mongo->disconnect(); | 
					
						
							|  |  |  |         $this->assertFalse($mongo->isConnected()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     public function testFind() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->find('items', array('name' => 'eggs'))->numRows()); | 
					
						
							|  |  |  |         $eggs = $mongo->find('items', array('name' => 'eggs')); | 
					
						
							|  |  |  |         $egg = $eggs->fetch(); | 
					
						
							|  |  |  |         $this->assertEquals(20, $egg->quantity); | 
					
						
							|  |  |  |         $egg = $eggs->fetchObject(); | 
					
						
							|  |  |  |         $this->assertEquals('eggs', $egg->name); | 
					
						
							|  |  |  |         $this->assertFalse($eggs->fetchObject()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertEquals(3, $mongo->find('items', array('price' => array('$lt' => 3.5)))->numRows()); | 
					
						
							|  |  |  |         $data = $mongo->find('items', array('price' => array('$lt' => 3.5))); | 
					
						
							|  |  |  |         $count = 0; | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  |         while ($row = $data->fetch(Db::FETCH_ASSOC)) { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |             $count++; | 
					
						
							|  |  |  |             $this->assertLessThan(3.5, $row['price']); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertEquals(3, $count); | 
					
						
							|  |  |  |         $this->assertEquals(5, $mongo->find('items', array())->numRows()); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |     public function testOrderSkipLimit() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $count = $mongo->find('items', array())->numRows(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->find('items', array('name' => 'eggs'))->numRows()); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'fdsbssc')); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'boc')); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'abc')); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'vcxxc')); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'abbc')); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'dsbssc')); | 
					
						
							|  |  |  |         $mongo->insert('items', array('name' => 'bssc')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $mongo->find('items', array()); | 
					
						
							|  |  |  |         $this->assertEquals($count + 7, $data->numRows()); | 
					
						
							|  |  |  |         $data->order(array('name' => 1)); | 
					
						
							|  |  |  |         $this->assertEquals('abbc', $data->fetch()->name); | 
					
						
							|  |  |  |         $this->assertEquals('abc', $data->fetch()->name); | 
					
						
							|  |  |  |         $this->assertEquals('boc', $data->fetch()->name); | 
					
						
							|  |  |  |         $data = $mongo->find('items', array()); | 
					
						
							|  |  |  |         $data->order(array('name' => -1)); | 
					
						
							|  |  |  |         $data->skip(3); | 
					
						
							|  |  |  |         $data->limit(1); | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  |         while ($row = $data->fetch()) { | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |             $this->assertEquals('fdsbssc', $row->name); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |     public function testCount() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |         $this->assertEquals(5, $mongo->count('items')); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->count('items', array('name' => 'eggs'))); | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->count('items', array('name' => 'eggs'), 1)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2012-02-06 18:12:23 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testCursorCount() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-02-06 18:12:23 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |         $this->assertEquals(5, $mongo->find('items')->count(5)); | 
					
						
							|  |  |  |         $this->assertCount(3, $mongo->find('items')->limit(3)->fetchAll()); | 
					
						
							|  |  |  |         $this->assertEquals(5, $mongo->count('items')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     public function testRemove() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $this->assertEquals(0, $mongo->delete('items', array('name' => 'esggs'))); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->delete('items', array('name' => 'eggs'))); | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->delete('items', array('name' => 'bread'))); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(0, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     public function testInsert() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(0, $mongo->insert('items', array('name' => 'bread'))); | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |         $this->assertNotEmpty($mongo->getInsertId()); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(2, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(0, $mongo->insert('items', array('name' => 'meat', 'weight' => 230))); | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $this->assertEquals(230, $mongo->find('items', array('name' => 'meat'))->fetch()->weight); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  |     public function testBatchInsert() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $data = array( | 
					
						
							|  |  |  |             array('name' => 'first object'), | 
					
						
							|  |  |  |             array('name' => 'second object'), | 
					
						
							|  |  |  |             array('name' => 'equal object'), | 
					
						
							|  |  |  |             array('name' => 'equal object') | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |         $mongo->insert('items', $data, true); | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'first object'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'second object'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->find('items', array('name' => 'equal object'))->numRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |     public function testGetInsertId() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-17 15:12:47 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |         $this->assertEquals(0, $mongo->getInsertId()); | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(0, $mongo->insert('items', array('name' => 'bread'))); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $id1 = $mongo->getInsertId(); | 
					
						
							|  |  |  |         $this->assertNotEmpty($id1); | 
					
						
							|  |  |  |         $this->assertEquals(0, $mongo->insert('items', array('name' => 'bread'))); | 
					
						
							|  |  |  |         $id2 = $mongo->getInsertId(); | 
					
						
							|  |  |  |         $this->assertNotEmpty($id2); | 
					
						
							|  |  |  |         $this->assertNotEquals($id1, $id2); | 
					
						
							|  |  |  |         $this->assertEquals(3, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     public function testUpdate() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows()); | 
					
						
							|  |  |  |         $this->assertEquals(1, $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'fish'))); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->update('items', array('$set' => array('price' => 1)), array('name' => 'eggs'))); | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $fish = $mongo->find('items', array('name' => 'fish'))->fetch(); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $this->assertEquals(200, $fish->price); | 
					
						
							|  |  |  |         $this->assertEquals('today', $fish->date); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $this->assertEquals(0, $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'ball'))); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     public function testUpsert() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:55 +04:00
										 |  |  |         $mongo->insert('items', array('name' => 'bread')); | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $this->assertInstanceOf('MongoId', $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'ball'), true, true)); | 
					
						
							|  |  |  |         $this->assertEquals('today', $mongo->find('items', array('name' => 'ball'))->fetch()->date); | 
					
						
							|  |  |  |         $this->assertEquals(2, $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'eggs'), true, true)); | 
					
						
							| 
									
										
										
										
											2011-11-15 11:12:20 +04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFindAndModify() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $this->assertEquals(10, $mongo->find('items', array('name' => 'bread'))->fetch()->quantity); | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |         $result = $mongo->findAndModify('items', array('name' => 'bread'), array('$set' => array('quantity' => 20))); | 
					
						
							|  |  |  |         $this->assertEquals(10, $result->fetch()->quantity); | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $this->assertEquals(20, $mongo->find('items', array('name' => 'bread'))->fetch()->quantity); | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							| 
									
										
										
										
											2011-12-06 16:53:16 +04:00
										 |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2012-06-05 13:52:39 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFindAndModifyNoItem() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-06-05 13:52:39 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $this->assertEquals(10, $mongo->find('items', array('name' => 'bread'))->fetch()->quantity); | 
					
						
							| 
									
										
										
										
											2012-06-05 13:52:39 +04:00
										 |  |  |         $result = $mongo->findAndModify('items', array('name' => 'breading'), array('$set' => array('quantity' => 20)))->fetch(); | 
					
						
							|  |  |  |         $this->assertFalse($result); | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |         $this->assertEquals(10, $mongo->find('items', array('name' => 'bread'))->fetch()->quantity); | 
					
						
							| 
									
										
										
										
											2012-06-05 13:52:39 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function testEvalCommand() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-06-05 13:52:39 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |         $result = $mongo->command('items', array('$eval' => 'function() { return db.items.count();}')); | 
					
						
							|  |  |  |         $this->assertEquals(5, $result->fetch()); | 
					
						
							|  |  |  |         $this->assertEquals(5, $mongo->count('items')); | 
					
						
							|  |  |  |         $result = $mongo->command('items', array('$eval' => 'function() { return "HELLO!";}')); | 
					
						
							|  |  |  |         $this->assertEquals("HELLO!", $result->fetch()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2012-04-13 16:22:52 +04:00
										 |  |  |     public function testEval() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2012-04-13 16:22:52 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							|  |  |  |         $result = $mongo->command('items', array('$eval' => 'function() {return true; }')); | 
					
						
							|  |  |  |         $this->assertTrue($result->fetch()); | 
					
						
							|  |  |  |         $result = $mongo->command('items', array('$eval' => 'function() {return "Hello"; }')); | 
					
						
							|  |  |  |         $this->assertSame('Hello', $result->fetch()); | 
					
						
							|  |  |  |         $result = $mongo->command('items', array('$eval' => 'function() {return db.items.count(); }')); | 
					
						
							|  |  |  |         $this->assertEquals(5, $result->fetch()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @runInSeparateProcess | 
					
						
							|  |  |  |      * @group Mongo | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |     public function testCommand() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-07-09 13:47:32 +04:00
										 |  |  |         Config::set('DEBUG', false); | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |         $mongo = new MongoDriver($this->conf); | 
					
						
							| 
									
										
										
										
											2012-01-18 23:30:34 +04:00
										 |  |  |         $result = $mongo->command('items', array('distinct' => 'items', 'key' => 'name')); | 
					
						
							| 
									
										
										
										
											2011-11-22 16:29:00 +04:00
										 |  |  |         $this->assertEquals(4, count($result->fetch(DB::FETCH_ASSOC))); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | } |