Add namespace.
This commit is contained in:
		
							
								
								
									
										389
									
								
								Tests/model/MongoDbCommandTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										389
									
								
								Tests/model/MongoDbCommandTest.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,389 @@ | ||||
| <?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/DbDriver.php'; | ||||
| require_once dirname(__FILE__) . '/../../model/NoSqlDbDriver.php'; | ||||
| require_once dirname(__FILE__) . '/../../model/MongoDriver.php'; | ||||
| require_once dirname(__FILE__) . '/../../model/MongoDbCommand.php'; | ||||
| require_once dirname(__FILE__) . '/../../exception/GeneralException.php'; | ||||
|  | ||||
| class   MongoDbCommandTest extends PHPUnit_Framework_TestCase | ||||
| { | ||||
|  | ||||
|     private $conf = array(); | ||||
|  | ||||
|     private $driver; | ||||
|  | ||||
|     private $collection; | ||||
|  | ||||
|     public function setUp() | ||||
|     { | ||||
|         $this->conf = array( | ||||
|             'hostname' => 'localhost', | ||||
|             'database' => 'test', | ||||
|             'username' => 'test', | ||||
|             'password' => '1234', | ||||
|             'port' => 27017 | ||||
|         ); | ||||
|         $this->driver = new MongoDriver($this->conf); | ||||
|         $connection = $this->driver->getConnection(); | ||||
|  | ||||
|         $db = $connection->selectDB($this->conf['database']); | ||||
|         $db->authenticate($this->conf['username'], $this->conf['password']); | ||||
|         $collection = 'items'; | ||||
|         $db->dropCollection($collection); | ||||
|         $this->collection = $db->selectCollection($collection); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testCommandFactory() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND); | ||||
|         $this->assertInstanceOf('MongoDbCommand', $cmd); | ||||
|         $this->assertInstanceOf('FindMongoCommand', $cmd); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT); | ||||
|         $this->assertInstanceOf('MongoDbCommand', $cmd); | ||||
|         $this->assertInstanceOf('InsertMongoCommand', $cmd); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::UPDATE); | ||||
|         $this->assertInstanceOf('MongoDbCommand', $cmd); | ||||
|         $this->assertInstanceOf('UpdateMongoCommand', $cmd); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::REMOVE); | ||||
|         $this->assertInstanceOf('MongoDbCommand', $cmd); | ||||
|         $this->assertInstanceOf('RemoveMongoCommand', $cmd); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testFindCommand() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'bread'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(0, $result->count()); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $cmd->execute(); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $cmd->execute(); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'insert'))->bindParam('fields', array()); | ||||
|         $this->assertEquals(2, $cmd->execute()->count()); | ||||
|  | ||||
|         $cmd | ||||
|                 ->bindParam('condition', array('name' => 'insert')) | ||||
|                 ->bindParam('fields', array()) | ||||
|                 ->bindParam('multiple', false); | ||||
|  | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals('insert', $result['name']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testCountCommand() | ||||
|     { | ||||
|         $count_cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COUNT, $this->collection); | ||||
|         $count_cmd->bindParam('condition', array('name' => 'bread')); | ||||
|         $count_result = $count_cmd->execute(); | ||||
|         $find_cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $find_cmd->bindParam('condition', array('name' => 'bread'))->bindParam('fields', array()); | ||||
|         $find_result = $find_cmd->execute(); | ||||
|         $this->assertEquals(0, $count_result); | ||||
|         $this->assertEquals($count_result, $find_result->count()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $cmd->execute(); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $cmd->execute(); | ||||
|  | ||||
|         $count_cmd->bindParam('condition', array('name' => 'insert')); | ||||
|         $this->assertEquals(2, $count_cmd->execute()); | ||||
|         $find_cmd->bindParam('condition', array('name' => 'insert')); | ||||
|         $this->assertEquals($find_cmd->execute()->count(), $count_cmd->execute()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testInsertCommand() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|  | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|  | ||||
|         $this->assertFalse($cmd->getInsertId()); | ||||
|  | ||||
|         $this->assertArrayHasKey('n', $cmd->execute()); | ||||
|         $this->assertNotEmpty($cmd->getInsertId()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'insert'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(1, $result->count()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testInsertCommandMultipleObjects() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|  | ||||
|         $data = array( | ||||
|             array('name' => 'first object'), | ||||
|             array('name' => 'second object'), | ||||
|             array('name' => 'equal object'), | ||||
|             array('name' => 'equal object') | ||||
|         ); | ||||
|         $cmd | ||||
|                 ->bindParam('data', $data) | ||||
|                 ->bindParam('multiple', true) | ||||
|                 ->bindParam('safe', true); | ||||
|  | ||||
|         $this->assertFalse($cmd->getInsertId()); | ||||
|  | ||||
|         $this->assertArrayHasKey('n', $cmd->execute()); | ||||
|  | ||||
|         $cmd->bindParam('data', array()); | ||||
|         $cmd->execute(); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'first object'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(1, $result->count()); | ||||
|         $cmd->bindParam('condition', array('name' => 'second object'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(1, $result->count()); | ||||
|         $cmd->bindParam('condition', array('name' => 'equal object'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(2, $result->count()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testInsertCommandNotAllParamsBinded() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $this->setExpectedException('GeneralException', 'InsertMongoCommand error. Bind all required params first'); | ||||
|         $cmd->execute(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testUpdateCommand() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertArrayHasKey('n', $cmd->execute()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::UPDATE, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('condition', array('name' => 'insert')) | ||||
|                 ->bindParam('data', array('$set' => array('name' => 'update'))) | ||||
|                 ->bindParam('upsert', false) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertArrayHasKey('n', $cmd->execute()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'insert'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(0, $result->count()); | ||||
|         $cmd->bindParam('condition', array('name' => 'update'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(1, $result->count()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testUpdateCommandNotAllParamsBinded() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::UPDATE, $this->collection); | ||||
|         $cmd->bindParam('data', array('name' => 'bread')); | ||||
|         $this->setExpectedException('GeneralException', 'UpdateMongoCommand error. Bind all required params first'); | ||||
|         $cmd->execute(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testRemoveCommand() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertArrayHasKey('n', $cmd->execute()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'insert'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(1, $result->count()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::REMOVE, $this->collection); | ||||
|         $cmd | ||||
|                 ->bindParam('condition', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertArrayHasKey('n', $cmd->execute()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->collection); | ||||
|         $cmd->bindParam('condition', array('name' => 'insert'))->bindParam('fields', array()); | ||||
|         $result = $cmd->execute(); | ||||
|         $this->assertEquals(0, $result->count()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testRemoveCommandNotAllParamsBinded() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::REMOVE, $this->collection); | ||||
|         $this->setExpectedException('GeneralException', 'RemoveMongoCommand error. Bind all required params first.'); | ||||
|         $cmd->execute(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testCommandCommandNotAllParamsBinded() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, $this->collection); | ||||
|         $this->setExpectedException('GeneralException', 'CommandMongoCommand error. Bind all required params first'); | ||||
|         $cmd->execute(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testCommandCommandNotMongoDb() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, new CollectionMock()); | ||||
|         $cmd->bindParam('command', array()); | ||||
|         $this->assertFalse($cmd->execute()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testCommandCommand() | ||||
|     { | ||||
|         $col = new CollectionMock(); | ||||
|         $col->db = $this->getMock('MongoDb', array('command'), array(), 'SomeMongoMock', false); | ||||
|         $col->db | ||||
|                 ->expects($this->once()) | ||||
|                 ->method('command') | ||||
|                 ->will($this->returnValue(true)); | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, $col); | ||||
|         $cmd->bindParam('command', array()); | ||||
|         $this->assertTrue($cmd->execute()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testToStringParamsNotSet() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, new CollectionMock()); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group Mongo | ||||
|      */ | ||||
|     public function testToString() | ||||
|     { | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COUNT); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd->bindParam('collection', new CollectionMock()); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: CollectionMock', $cmd->__toString()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::FIND); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd->bindParam('collection', new CollectionMock()); | ||||
|         $cmd->bindParam('condition', array()); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: CollectionMock', $cmd->__toString()); | ||||
|         $this->assertContains('Condition: ' . '[]' . PHP_EOL, $cmd->__toString()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, new CollectionMock()); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd->bindParam('command', array()); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: CollectionMock', $cmd->__toString()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: ', $cmd->__toString()); | ||||
|         $this->assertContains('Bulk insert: FALSE', $cmd->__toString()); | ||||
|         $this->assertContains('Data: ' . '[' . PHP_EOL . "\tname = insert" . PHP_EOL . ']' . PHP_EOL, $cmd->__toString()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->collection); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd | ||||
|                 ->bindParam('data', array('name' => 'insert')) | ||||
|                 ->bindParam('multiple', true) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertContains('Bulk insert: TRUE', $cmd->__toString()); | ||||
|  | ||||
|         $cmd->bindParam('condition', array('name' => 'insert'))->bindParam('fields', array()); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: ', $cmd->__toString()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::REMOVE, $this->collection); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd | ||||
|                 ->bindParam('condition', array('name' => 'insert')) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: ', $cmd->__toString()); | ||||
|  | ||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::UPDATE, $this->collection); | ||||
|         $this->assertSame('Command properties not set', $cmd->__toString()); | ||||
|         $cmd | ||||
|                 ->bindParam('condition', array('name' => 'insert')) | ||||
|                 ->bindParam('data', array('$set' => array('name' => 'update'))) | ||||
|                 ->bindParam('upsert', false) | ||||
|                 ->bindParam('safe', true); | ||||
|         $this->assertStringStartsWith("\n" . 'Collection: ', $cmd->__toString()); | ||||
|     } | ||||
| } | ||||
|  | ||||
| class CollectionMock | ||||
| { | ||||
|     public $db = array(); | ||||
|  | ||||
|     public function __toString() | ||||
|     { | ||||
|         return PHP_EOL . 'CollectionMock'; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user