329 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			329 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * @copyright NetMonsters <team@netmonsters.ru>
 | |
|  * @link http://netmonsters.ru
 | |
|  * @package Majestic
 | |
|  * @subpackage UnitTests
 | |
|  * @since 2011-11-10
 | |
|  * 
 | |
|  * Unit tests for MongoDriver class
 | |
|  */
 | |
| 
 | |
| require_once dirname(__FILE__) . '/../../model/Db.php';
 | |
| require_once dirname(__FILE__) . '/../../model/DbDriver.php';
 | |
| require_once dirname(__FILE__) . '/../../model/NoSqlDbDriver.php';
 | |
| require_once dirname(__FILE__) . '/../../model/MongoDbCommand.php';
 | |
| require_once dirname(__FILE__) . '/../../model/DbStatement.php';
 | |
| require_once dirname(__FILE__) . '/../../model/MongoStatement.php';
 | |
| require_once dirname(__FILE__) . '/../../model/MongoDriver.php';
 | |
| 
 | |
| 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
 | |
|         );
 | |
| 
 | |
|         $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);
 | |
|         foreach($data as $document) {
 | |
|             $collection->insert($document);     
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      * @expectedExceptionMessage Configuration must have a "hostname".
 | |
|      */
 | |
|     public function testGetConnectionNoHostname()
 | |
|     {
 | |
|         unset($this->conf['hostname']);
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $mongo->getConnection();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException MongoConnectionException
 | |
|      * @expectedExceptionMessage Couldn't authenticate with database
 | |
|      */
 | |
|     public function testGetConnectionWrongPassword()
 | |
|     {
 | |
|         $this->conf['password'] = 'nopass';
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $this->assertInstanceOf('MongoDB', $mongo->getConnection());
 | |
|     }
 | |
| 
 | |
|     public function testGetConnection()
 | |
|     {
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
| 
 | |
|         $this->assertFalse($mongo->isConnected());
 | |
|         $this->assertInstanceOf('Mongo', $mongo->getConnection());
 | |
|         $this->assertTrue($mongo->isConnected());
 | |
|         $mongo->getConnection();
 | |
|         $mongo->disconnect();
 | |
|         $this->assertFalse($mongo->isConnected());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testFind()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
|         
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $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;
 | |
|         while($row = $data->fetch(Db::FETCH_ASSOC)) {
 | |
|             $count++;
 | |
|             $this->assertLessThan(3.5, $row['price']);
 | |
|         }
 | |
|         $this->assertEquals(3, $count);
 | |
|         $this->assertEquals(5, $mongo->find('items', array())->numRows());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testOrderSkipLimit()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $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);
 | |
|         while($row = $data->fetch()) {
 | |
|             $this->assertEquals('fdsbssc', $row->name);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testCount()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
|         $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
 | |
|      */
 | |
|     public function testGet()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $eggs = $mongo->get('items', array('name' => 'eggs'))->fetchObject();
 | |
|         $this->assertEquals(20, $eggs->quantity);
 | |
|         $eggs = $mongo->get('items', array('name' => 'eggs'))->fetch();
 | |
|         $this->assertEquals('eggs', $eggs->name);
 | |
|         $this->assertInstanceOf('MongoId', $eggs->_id);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testRemove()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows());
 | |
|         $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')));
 | |
|         $this->assertEquals(0, $mongo->find('items', array('name' => 'bread'))->numRows());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testInsert()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $this->assertEquals(1, $mongo->find('items', array('name' => 'bread'))->numRows());
 | |
|         $this->assertEquals(0, $mongo->insert('items', array('name' => 'bread')));
 | |
|         $this->assertNotEmpty($mongo->getInsertId());
 | |
|         $this->assertEquals(2, $mongo->find('items', array('name' => 'bread'))->numRows());
 | |
|         $this->assertEquals(0, $mongo->insert('items', array('name' => 'meat', 'weight' => 230)));
 | |
|         $this->assertEquals(230, $mongo->get('items', array('name' => 'meat'))->fetch()->weight);
 | |
|     }
 | |
| 
 | |
|     public function testGetInsertId()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
|         
 | |
|         $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());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testUpdate()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $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')));
 | |
|         $fish = $mongo->get('items', array('name' => 'fish'))->fetch();
 | |
|         $this->assertEquals(200, $fish->price);
 | |
|         $this->assertEquals('today', $fish->date);
 | |
|         $this->assertEquals(0, $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'ball')));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testUpsert()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
| 
 | |
|         $mongo->insert('items', array('name' => 'bread'));
 | |
|         $this->assertEquals(1, $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'ball'), true, true));
 | |
|         $this->assertEquals('today', $mongo->get('items', array('name' => 'ball'))->fetch()->date);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testFindAndModify()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
| 
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
| 
 | |
|         $this->assertEquals(10, $mongo->get('items', array('name' => 'bread'))->fetch()->quantity);
 | |
|         $result = $mongo->findAndModify('items', array('name' => 'bread'), array('$set' => array('quantity' => 20)));
 | |
|         $this->assertEquals(10, $result->fetch()->quantity);
 | |
|         $this->assertEquals(20, $mongo->get('items', array('name' => 'bread'))->fetch()->quantity);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @runInSeparateProcess
 | |
|      */
 | |
|     public function testCommand()
 | |
|     {
 | |
|         if (!defined('DEBUG')) {
 | |
|             define('DEBUG', false);
 | |
|         }
 | |
|         $mongo = new MongoDriver($this->conf);
 | |
|         $result = $mongo->command('items', array('distinct' =>'items', 'key' => 'name'));
 | |
|         $this->assertEquals(4, count($result->fetch(DB::FETCH_ASSOC)));
 | |
| 
 | |
| 
 | |
| 
 | |
|     }
 | |
| } |