| 
									
										
										
										
											2011-11-03 16:52:33 +04:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage UnitTests | 
					
						
							|  |  |  |  * @since 2011-11-3 | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * Unit tests for DbDriver class | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/DbExpr.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/Db.php'; | 
					
						
							|  |  |  | require_once dirname(__FILE__) . '/../../model/DbDriver.php'; | 
					
						
							| 
									
										
										
										
											2011-11-25 19:50:41 +04:00
										 |  |  | require_once dirname(__FILE__) . '/../../exception/GeneralException.php'; | 
					
						
							| 
									
										
										
										
											2011-11-03 16:52:33 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | class DbDriverTest extends PHPUnit_Framework_TestCase | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     private $driver; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function setUp() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $conf = array('hostname' => 'localhost', 'database' => 'db', 'username' => 'test', 'password' => '1234'); | 
					
						
							|  |  |  |         $this->driver = $this->getMockForAbstractClass('DbDriver', array($conf)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testConstruct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $conf = array('hostname' => 'localhost', 'database' => 'db', 'username' => 'test', 'password' => '1234'); | 
					
						
							| 
									
										
										
										
											2011-12-01 17:35:13 +04:00
										 |  |  |         try { | 
					
						
							|  |  |  |             $this->driver = $this->getMockForAbstractClass('DbDriver', array($conf)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         catch (GeneralException $expected) { | 
					
						
							|  |  |  |             $this->fail($expected->getMessage()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->assertInstanceOf('DbDriver', $this->driver); | 
					
						
							| 
									
										
										
										
											2011-11-03 16:52:33 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testConstructWrongConfig() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-12-01 17:35:13 +04:00
										 |  |  |         $this->setExpectedException('GeneralException', 'Configuration must have a "username"'); | 
					
						
							| 
									
										
										
										
											2011-11-03 16:52:33 +04:00
										 |  |  |         $conf = array('hostname' => 'localhost', 'database' => 'db'); | 
					
						
							|  |  |  |         $this->getMockForAbstractClass('DbDriver', array($conf)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testGetConnection() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->assertNull($this->driver->getConnection()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testBeginTransaction() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->assertEquals($this->driver, $this->driver->beginTransaction()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testCommit() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->assertEquals($this->driver, $this->driver->commit()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testRollback() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->assertEquals($this->driver, $this->driver->rollback()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testQuery() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $stmt = $this->driver->query('SELECT * FROM table'); | 
					
						
							|  |  |  |         $this->assertInstanceOf('DbStmt', $stmt); | 
					
						
							|  |  |  |         $this->assertEquals('SELECT * FROM table', $stmt->string()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $stmt = $this->driver->query('SELECT * FROM table', 'simple'); | 
					
						
							|  |  |  |         $this->assertInstanceOf('DbStmt', $stmt); | 
					
						
							|  |  |  |         $this->assertEquals('SELECT * FROM table', $stmt->string()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testInsert() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction() | 
					
						
							|  |  |  |                 ->setDriverQuoteFunction(); | 
					
						
							|  |  |  |         $bind = array('table.name' => 'tony', 'chair.age' => 21, 'height' => 185); | 
					
						
							|  |  |  |         $sql = $this->driver->insert('users', $bind); | 
					
						
							|  |  |  |         $this->assertEquals('INSERT INTO `users` (`table`.`name`, `chair`.`age`, `height`) VALUES (tony, 21, 185)', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testUpdate() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction() | 
					
						
							|  |  |  |                 ->setDriverQuoteFunction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $bind = array('table.name' => 'tony', 'chair.age' => 21, 'height' => 185); | 
					
						
							|  |  |  |         $sql = $this->driver->update('users', $bind); | 
					
						
							|  |  |  |         $this->assertEquals('UPDATE `users` SET `table`.`name`=tony, `chair`.`age`=21, `height`=185', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testDeleteNoWHERE() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = $this->driver->delete('users'); | 
					
						
							|  |  |  |         $this->assertEquals('DELETE FROM `users`', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testDeleteWithWHEREArray() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction() | 
					
						
							|  |  |  |                 ->setDriverQuoteFunction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = $this->driver->delete('users', array('name?tony' => new DbExpr('='), 'height?185' => '>')); | 
					
						
							|  |  |  |         $this->assertEquals('DELETE FROM `users` WHERE name=tony AND height>185', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testDeleteWithWHERESimpleCond() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = $this->driver->delete('users', 'name=tony'); | 
					
						
							|  |  |  |         $this->assertEquals('DELETE FROM `users` WHERE name=tony', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testDeleteWithWHEREKeyArray() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sql = $this->driver->delete('users', array('name=tony' => 0)); | 
					
						
							|  |  |  |         $this->assertEquals('DELETE FROM `users` WHERE name=tony', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testDeleteWithWHEREDbExpr() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->setDriverPrepareFunction(); | 
					
						
							| 
									
										
										
										
											2011-12-01 17:35:13 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-03 16:52:33 +04:00
										 |  |  |         $sql = $this->driver->delete('users', new DbExpr('name=tony')); | 
					
						
							|  |  |  |         $this->assertEquals('DELETE FROM `users` WHERE name=tony', $sql); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function setDriverPrepareFunction() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('prepare') | 
					
						
							|  |  |  |                 ->with($this->anything()) | 
					
						
							|  |  |  |                 ->will($this->returnCallback(array($this, 'dbDriverPrepare'))); | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function setDriverQuoteFunction() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->driver | 
					
						
							|  |  |  |                 ->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('driverQuote') | 
					
						
							|  |  |  |                 ->with($this->anything()) | 
					
						
							|  |  |  |                 ->will($this->returnArgument(0)); | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function dbDriverPrepare($sql) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $stmt = $this->getMock('DbStmt', array('execute', 'string', 'affectedRows')); | 
					
						
							|  |  |  |         $stmt->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('execute') | 
					
						
							|  |  |  |                 ->with($this->anything()); | 
					
						
							|  |  |  |         $stmt->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('string') | 
					
						
							|  |  |  |                 ->will($this->returnValue($sql)); | 
					
						
							|  |  |  |         $stmt->expects($this->any()) | 
					
						
							|  |  |  |                 ->method('affectedRows') | 
					
						
							|  |  |  |                 ->will($this->returnValue($sql)); | 
					
						
							|  |  |  |         return $stmt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |