diff options
author | Bernhard Posselt <dev@bernhard-posselt.com> | 2015-03-19 14:55:21 +0100 |
---|---|---|
committer | Bernhard Posselt <dev@bernhard-posselt.com> | 2015-03-19 17:08:46 +0100 |
commit | df24a014b8bc205e6bc047ead2af393b3e169542 (patch) | |
tree | 78648ce5663a2cda89e4107103d3d210116aea39 /tests | |
parent | 857b22c61be8f78581f41ac155efeff34ed335cd (diff) | |
download | nextcloud-server-df24a014b8bc205e6bc047ead2af393b3e169542.tar.gz nextcloud-server-df24a014b8bc205e6bc047ead2af393b3e169542.zip |
If the execute method on the mapper receives an assoc array, it binds by value instead of index
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/appframework/db/mappertest.php | 10 | ||||
-rw-r--r-- | tests/lib/appframework/db/mappertestutility.php | 69 |
2 files changed, 54 insertions, 25 deletions
diff --git a/tests/lib/appframework/db/mappertest.php b/tests/lib/appframework/db/mappertest.php index 8e585c479bb..c8b999ad62c 100644 --- a/tests/lib/appframework/db/mappertest.php +++ b/tests/lib/appframework/db/mappertest.php @@ -47,6 +47,7 @@ class ExampleMapper extends Mapper { public function findOneEntity($table, $id){ return $this->findEntity($table, $id); } public function findAllEntities($table){ return $this->findEntities($table); } public function mapRow($row){ return $this->mapRowToEntity($row); } + public function execSql($sql, $params){ return $this->execute($sql, $params); } } @@ -187,6 +188,15 @@ class MapperTest extends MapperTestUtility { } + public function testAssocParameters() { + $sql = 'test'; + $params = [':test' => 1, ':a' => 2]; + + $this->setMapperResult($sql, $params); + $this->mapper->execSql($sql, $params); + } + + public function testUpdate(){ $sql = 'UPDATE `*PREFIX*table` ' . 'SET ' . diff --git a/tests/lib/appframework/db/mappertestutility.php b/tests/lib/appframework/db/mappertestutility.php index c87ad528c03..818e4a59b21 100644 --- a/tests/lib/appframework/db/mappertestutility.php +++ b/tests/lib/appframework/db/mappertestutility.php @@ -56,7 +56,30 @@ abstract class MapperTestUtility extends \Test\TestCase { $this->fetchAt = 0; } + /** + * Checks if an array is associative + * @param array $array + * @return bool true if associative + */ + private function isAssocArray(array $array) { + return array_values($array) !== $array; + } + /** + * Returns the correct PDO constant based on the value type + * @param $value + * @return PDO constant + */ + private function getPDOType($value) { + switch (gettype($value)) { + case 'integer': + return \PDO::PARAM_INT; + case 'boolean': + return \PDO::PARAM_BOOL; + default: + return \PDO::PARAM_STR; + } + } /** * Create mocks and set expected results for database queries @@ -117,32 +140,28 @@ abstract class MapperTestUtility extends \Test\TestCase { } )); - $index = 1; - foreach($arguments as $argument) { - switch (gettype($argument)) { - case 'integer': - $pdoConstant = \PDO::PARAM_INT; - break; - - case 'NULL': - $pdoConstant = \PDO::PARAM_NULL; - break; - - case 'boolean': - $pdoConstant = \PDO::PARAM_BOOL; - break; - - default: - $pdoConstant = \PDO::PARAM_STR; - break; + if ($this->isAssocArray($arguments)) { + foreach($arguments as $key => $argument) { + $pdoConstant = $this->getPDOType($argument); + $this->query->expects($this->at($this->queryAt)) + ->method('bindValue') + ->with($this->equalTo($key), + $this->equalTo($argument), + $this->equalTo($pdoConstant)); + $this->queryAt++; + } + } else { + $index = 1; + foreach($arguments as $argument) { + $pdoConstant = $this->getPDOType($argument); + $this->query->expects($this->at($this->queryAt)) + ->method('bindValue') + ->with($this->equalTo($index), + $this->equalTo($argument), + $this->equalTo($pdoConstant)); + $index++; + $this->queryAt++; } - $this->query->expects($this->at($this->queryAt)) - ->method('bindValue') - ->with($this->equalTo($index), - $this->equalTo($argument), - $this->equalTo($pdoConstant)); - $index++; - $this->queryAt++; } $this->query->expects($this->at($this->queryAt)) |