added methods to MongoDriver for custom commands, findAndModify, count
This commit is contained in:
		| @ -18,6 +18,8 @@ class MongoCommandBuilder | |||||||
|  |  | ||||||
|     const REMOVE = 'Remove'; |     const REMOVE = 'Remove'; | ||||||
|  |  | ||||||
|  |     const COMMAND = 'Command'; | ||||||
|  |  | ||||||
|     static public function factory($type, $collection = null) |     static public function factory($type, $collection = null) | ||||||
|     { |     { | ||||||
|         $class = ucfirst($type) . 'MongoCommand'; |         $class = ucfirst($type) . 'MongoCommand'; | ||||||
| @ -167,4 +169,26 @@ class RemoveMongoCommand extends MongoDbCommand | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  class CommandMongoCommand extends MongoDbCommand | ||||||
|  |  { | ||||||
|  |      protected $command; | ||||||
|  |  | ||||||
|  |      protected function concreteExecute() | ||||||
|  |      { | ||||||
|  |          $db = $this->collection->db; | ||||||
|  |          if($db instanceof MongoDB) { | ||||||
|  |              return $db->command($this->command); | ||||||
|  |          } else { | ||||||
|  |              return false; | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  |  | ||||||
|  |     protected function checkParams() | ||||||
|  |     { | ||||||
|  |         if (isset($this->collection) && isset($this->command)) { | ||||||
|  |             return true; | ||||||
|  |         } else { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  } | ||||||
|  | |||||||
| @ -26,6 +26,11 @@ class MongoDriver extends NoSqlDbDriver | |||||||
|         return $this->connection->selectCollection($this->db, $name); |         return $this->connection->selectCollection($this->db, $name); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public function count($collection, $query = array(), $limit = 0, $skip = 0) | ||||||
|  |     { | ||||||
|  |         return $this->getCollection($collection)->count($query, $limit, $skip); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public function find($collection, $condition = array(), $fields = array()) |     public function find($collection, $condition = array(), $fields = array()) | ||||||
|     { |     { | ||||||
|         $command = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->getCollection($collection)); |         $command = MongoCommandBuilder::factory(MongoCommandBuilder::FIND, $this->getCollection($collection)); | ||||||
| @ -48,6 +53,30 @@ class MongoDriver extends NoSqlDbDriver | |||||||
|         return $this->query($command, $params); |         return $this->query($command, $params); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public function findAndModify($collection, $query, $update, $sort = array(), $field = array(), $upsert = false, $new = false, $remove = false) | ||||||
|  |     { | ||||||
|  |         $command = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, $this->getCollection($collection)); | ||||||
|  |         $cmd = array( | ||||||
|  |             'findAndModify' => $collection, | ||||||
|  |             'query' => $query, | ||||||
|  |             'update' => $update, | ||||||
|  |             'sort' => $sort, | ||||||
|  |             'fields' => $field, | ||||||
|  |             'new' => $new, | ||||||
|  |             'upsert' => $upsert, | ||||||
|  |             'remove' => $remove | ||||||
|  |         ); | ||||||
|  |         $params = array('command' => $cmd); | ||||||
|  |         return $this->query($command, $params); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function command($collection, $cmd) | ||||||
|  |     { | ||||||
|  |         $command = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, $this->getCollection($collection)); | ||||||
|  |         $params = array('command' => $cmd); | ||||||
|  |         return $this->query($command, $params); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public function insert($collection, $data, $safe = true) |     public function insert($collection, $data, $safe = true) | ||||||
|     { |     { | ||||||
|         $command = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->getCollection($collection)); |         $command = MongoCommandBuilder::factory(MongoCommandBuilder::INSERT, $this->getCollection($collection)); | ||||||
| @ -85,6 +114,8 @@ class MongoDriver extends NoSqlDbDriver | |||||||
|         return $this->query($command, $params)->affectedRows(); |         return $this->query($command, $params)->affectedRows(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param mixed $request |      * @param mixed $request | ||||||
|      * @return DbStatement |      * @return DbStatement | ||||||
|  | |||||||
| @ -13,6 +13,11 @@ | |||||||
| abstract class MongoModel extends Model | abstract class MongoModel extends Model | ||||||
| { | { | ||||||
|  |  | ||||||
|  |     public function count($query = array(), $limit = 0, $skip = 0) | ||||||
|  |     { | ||||||
|  |         return $this->db->count($this->table(), $query, $limit, $skip); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public function find($condition = array()) |     public function find($condition = array()) | ||||||
|     { |     { | ||||||
|         return $this->db->find($this->table(), $condition); |         return $this->db->find($this->table(), $condition); | ||||||
|  | |||||||
| @ -96,8 +96,10 @@ class MongoStatement extends DbStatement | |||||||
|     public function affectedRows() |     public function affectedRows() | ||||||
|     { |     { | ||||||
|         if (is_array($this->result)) { |         if (is_array($this->result)) { | ||||||
|             if (isset($this->result['ok']) && $this->result['ok'] == 1 && isset($this->result['n'])) { |             if (isset($this->result['ok']) && $this->result['ok'] == 1) { | ||||||
|  |                 if (isset($this->result['n'])) { | ||||||
|                     return $this->result['n']; |                     return $this->result['n']; | ||||||
|  |                 } | ||||||
|             } else { |             } else { | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| @ -115,7 +117,7 @@ class MongoStatement extends DbStatement | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param MongoDbComand $request |      * @param MongoDbCommand $request | ||||||
|      * @return bool |      * @return bool | ||||||
|      */ |      */ | ||||||
|     protected function driverExecute($request) |     protected function driverExecute($request) | ||||||
| @ -134,8 +136,14 @@ class MongoStatement extends DbStatement | |||||||
|             } |             } | ||||||
|             if ($result instanceof MongoCursor || is_array($result)) { |             if ($result instanceof MongoCursor || is_array($result)) { | ||||||
|                 $this->result = $result; |                 $this->result = $result; | ||||||
|  |                 if (is_array($result) && isset($result['value'])) { | ||||||
|  |                     $this->result = $result['value']; | ||||||
|                 } |                 } | ||||||
|             if($request instanceof InsertMongoCommand) { |                 if (is_array($result) && isset($result['values'])) { | ||||||
|  |                     $this->result = $result['values']; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if ($request instanceof InsertMongoCommand) { | ||||||
|                 $this->insertId = $request->getInsertId(); |                 $this->insertId = $request->getInsertId(); | ||||||
|             } |             } | ||||||
|             return true; |             return true; | ||||||
|  | |||||||
| @ -199,4 +199,26 @@ class MongoDbCommandTest extends PHPUnit_Framework_TestCase | |||||||
|         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::REMOVE, $this->collection); |         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::REMOVE, $this->collection); | ||||||
|         $cmd->execute(); |         $cmd->execute(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @expectedException Exception | ||||||
|  |      * @expectedExceptionMessage CommandMongoCommand error. Bind all required params first. | ||||||
|  |      */ | ||||||
|  |     public function testCommandCommandNotAllParamsBinded() | ||||||
|  |     { | ||||||
|  |         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, $this->collection); | ||||||
|  |         $cmd->execute(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testCommandCommandNotMongoDb() | ||||||
|  |     { | ||||||
|  |         $cmd = MongoCommandBuilder::factory(MongoCommandBuilder::COMMAND, new CollectionMock()); | ||||||
|  |         $cmd->bindParam('command', array()); | ||||||
|  |         $this->assertFalse($cmd->execute()); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class CollectionMock | ||||||
|  | { | ||||||
|  |     public $db = array(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -176,6 +176,20 @@ class MongoDriverTest extends PHPUnit_Framework_TestCase | |||||||
|     /** |     /** | ||||||
|      * @runInSeparateProcess |      * @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() |     public function testGet() | ||||||
|     { |     { | ||||||
|         if (!defined('DEBUG')) { |         if (!defined('DEBUG')) { | ||||||
| @ -279,4 +293,37 @@ class MongoDriverTest extends PHPUnit_Framework_TestCase | |||||||
|         $this->assertEquals(1, $mongo->update('items', array('$set' => array('price' => 200, 'date' => 'today')), array('name' => 'ball'), true, true)); |         $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); |         $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))); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -101,6 +101,18 @@ class MongoModelTest extends PHPUnit_Framework_TestCase | |||||||
|     /** |     /** | ||||||
|      * @runInSeparateProcess |      * @runInSeparateProcess | ||||||
|      */ |      */ | ||||||
|  |     public function testCount() | ||||||
|  |     { | ||||||
|  |         if (!defined('DEBUG')) { | ||||||
|  |             define('DEBUG', false); | ||||||
|  |         } | ||||||
|  |         $this->assertEquals(5, $this->model->count()); | ||||||
|  |         $this->assertEquals(2, $this->model->count(array('name' => 'eggs'))); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @runInSeparateProcess | ||||||
|  |      */ | ||||||
|     public function testFetch() |     public function testFetch() | ||||||
|     { |     { | ||||||
|         if (!defined('DEBUG')) { |         if (!defined('DEBUG')) { | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user