summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorMarius David Wieschollek <git.public@mdns.eu>2019-03-24 22:35:23 +0100
committerMarius David Wieschollek <git.public@mdns.eu>2019-03-24 22:43:45 +0100
commit5aeb8eac2bcfd13760d779aec9027ffc955011d9 (patch)
tree9ab69f11cbf0f49e7231e59196601058e4c4e844 /tests
parentfb1e555b5aad8efe5fe9c78a8161b991ac8e2048 (diff)
downloadnextcloud-server-5aeb8eac2bcfd13760d779aec9027ffc955011d9.tar.gz
nextcloud-server-5aeb8eac2bcfd13760d779aec9027ffc955011d9.zip
[#11236] Set parameter type in QBMapper
Signed-off-by: Marius David Wieschollek <git.public@mdns.eu>
Diffstat (limited to 'tests')
-rw-r--r--tests/lib/AppFramework/Db/QBMapperTest.php241
1 files changed, 241 insertions, 0 deletions
diff --git a/tests/lib/AppFramework/Db/QBMapperTest.php b/tests/lib/AppFramework/Db/QBMapperTest.php
new file mode 100644
index 00000000000..673d8132836
--- /dev/null
+++ b/tests/lib/AppFramework/Db/QBMapperTest.php
@@ -0,0 +1,241 @@
+<?php
+/**
+ * @copyright 2019, Marius David Wieschollek <git.public@mdns.eu>
+ *
+ * @author Marius David Wieschollek <git.public@mdns.eu>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace Test\AppFramework\Db;
+
+use OCP\AppFramework\Db\Entity;
+use OCP\AppFramework\Db\QBMapper;
+use OCP\DB\QueryBuilder\IExpressionBuilder;
+use OCP\DB\QueryBuilder\IQueryBuilder;
+use OCP\IDBConnection;
+
+/**
+ * @method bool getBoolProp()
+ * @method void setBoolProp(bool $boolProp)
+ * @method integer getIntProp()
+ * @method void setIntProp(integer $intProp)
+ * @method string getStringProp()
+ * @method void setStringProp(string $stringProp)
+ * @method bool getBooleanProp()
+ * @method void setBooleanProp(bool $booleanProp)
+ * @method integer getIntegerProp()
+ * @method void setIntegerProp(integer $integerProp)
+ */
+class QBTestEntity extends Entity {
+
+ protected $intProp;
+ protected $boolProp;
+ protected $stringProp;
+ protected $integerProp;
+ protected $booleanProp;
+
+ public function __construct() {
+ $this->addType('intProp', 'int');
+ $this->addType('boolProp', 'bool');
+ $this->addType('stringProp', 'string');
+ $this->addType('integerProp', 'integer');
+ $this->addType('booleanProp', 'boolean');
+ }
+}
+
+;
+
+/**
+ * Class QBTestMapper
+ *
+ * @package Test\AppFramework\Db
+ */
+class QBTestMapper extends QBMapper {
+ public function __construct(IDBConnection $db) {
+ parent::__construct($db, 'table');
+ }
+
+ public function getParameterTypeForPropertyForTest(Entity $entity, string $property): int {
+ return parent::getParameterTypeForProperty($entity, $property);
+ }
+}
+
+/**
+ * Class QBMapperTest
+ *
+ * @package Test\AppFramework\Db
+ */
+class QBMapperTest extends \Test\TestCase {
+
+ /**
+ * @var \PHPUnit\Framework\MockObject\MockObject|IDBConnection
+ */
+ protected $db;
+
+ /**
+ * @var \PHPUnit\Framework\MockObject\MockObject|IQueryBuilder
+ */
+ protected $qb;
+
+ /**
+ * @var \PHPUnit\Framework\MockObject\MockObject|IExpressionBuilder
+ */
+ protected $expr;
+
+ /**
+ * @var \Test\AppFramework\Db\QBTestMapper
+ */
+ protected $mapper;
+
+ /**
+ * @throws \ReflectionException
+ */
+ protected function setUp() {
+
+ $this->db = $this->getMockBuilder(IDBConnection::class)
+ ->disableOriginalConstructor()
+ ->getMock();
+
+ $this->qb = $this->getMockBuilder(IQueryBuilder:: class)
+ ->disableOriginalConstructor()
+ ->getMock();
+
+ $this->expr = $this->getMockBuilder(IExpressionBuilder:: class)
+ ->disableOriginalConstructor()
+ ->getMock();
+
+
+ $this->qb->method('expr')->willReturn($this->expr);
+ $this->db->method('getQueryBuilder')->willReturn($this->qb);
+
+
+ $this->mapper = new QBTestMapper($this->db);
+ }
+
+ /**
+ *
+ */
+ public function testInsertEntityParameterTypeMapping() {
+ $entity = new QBTestEntity();
+ $entity->setIntProp(123);
+ $entity->setBoolProp(true);
+ $entity->setStringProp('string');
+ $entity->setIntegerProp(456);
+ $entity->setBooleanProp(false);
+
+ $intParam = $this->qb->createNamedParameter('int_prop', IQueryBuilder::PARAM_INT);
+ $boolParam = $this->qb->createNamedParameter('bool_prop', IQueryBuilder::PARAM_BOOL);
+ $stringParam = $this->qb->createNamedParameter('string_prop', IQueryBuilder::PARAM_STR);
+ $integerParam = $this->qb->createNamedParameter('integer_prop', IQueryBuilder::PARAM_INT);
+ $booleanParam = $this->qb->createNamedParameter('boolean_prop', IQueryBuilder::PARAM_BOOL);
+
+ $this->qb->expects($this->exactly(5))
+ ->method('createNamedParameter')
+ ->withConsecutive(
+ [$this->equalTo(123), $this->equalTo(IQueryBuilder::PARAM_INT)],
+ [$this->equalTo(true), $this->equalTo(IQueryBuilder::PARAM_BOOL)],
+ [$this->equalTo('string'), $this->equalTo(IQueryBuilder::PARAM_STR)],
+ [$this->equalTo(456), $this->equalTo(IQueryBuilder::PARAM_INT)],
+ [$this->equalTo(false), $this->equalTo(IQueryBuilder::PARAM_BOOL)]
+ );
+ $this->qb->expects($this->exactly(5))
+ ->method('setValue')
+ ->withConsecutive(
+ [$this->equalTo('int_prop'), $this->equalTo($intParam)],
+ [$this->equalTo('bool_prop'), $this->equalTo($boolParam)],
+ [$this->equalTo('string_prop'), $this->equalTo($stringParam)],
+ [$this->equalTo('integer_prop'), $this->equalTo($integerParam)],
+ [$this->equalTo('boolean_prop'), $this->equalTo($booleanParam)]
+ );
+
+ $this->mapper->insert($entity);
+ }
+
+ /**
+ *
+ */
+ public function testUpdateEntityParameterTypeMapping() {
+ $entity = new QBTestEntity();
+ $entity->setId(789);
+ $entity->setIntProp(123);
+ $entity->setBoolProp('true');
+ $entity->setStringProp('string');
+ $entity->setIntegerProp(456);
+ $entity->setBooleanProp(false);
+
+ $idParam = $this->qb->createNamedParameter('id', IQueryBuilder::PARAM_INT);
+ $intParam = $this->qb->createNamedParameter('int_prop', IQueryBuilder::PARAM_INT);
+ $boolParam = $this->qb->createNamedParameter('bool_prop', IQueryBuilder::PARAM_BOOL);
+ $stringParam = $this->qb->createNamedParameter('string_prop', IQueryBuilder::PARAM_STR);
+ $integerParam = $this->qb->createNamedParameter('integer_prop', IQueryBuilder::PARAM_INT);
+ $booleanParam = $this->qb->createNamedParameter('boolean_prop', IQueryBuilder::PARAM_BOOL);
+
+ $this->qb->expects($this->exactly(6))
+ ->method('createNamedParameter')
+ ->withConsecutive(
+ [$this->equalTo(123), $this->equalTo(IQueryBuilder::PARAM_INT)],
+ [$this->equalTo(true), $this->equalTo(IQueryBuilder::PARAM_BOOL)],
+ [$this->equalTo('string'), $this->equalTo(IQueryBuilder::PARAM_STR)],
+ [$this->equalTo(456), $this->equalTo(IQueryBuilder::PARAM_INT)],
+ [$this->equalTo(false), $this->equalTo(IQueryBuilder::PARAM_BOOL)],
+ [$this->equalTo(789), $this->equalTo(IQueryBuilder::PARAM_INT)]
+ );
+
+ $this->qb->expects($this->exactly(5))
+ ->method('set')
+ ->withConsecutive(
+ [$this->equalTo('int_prop'), $this->equalTo($intParam)],
+ [$this->equalTo('bool_prop'), $this->equalTo($boolParam)],
+ [$this->equalTo('string_prop'), $this->equalTo($stringParam)],
+ [$this->equalTo('integer_prop'), $this->equalTo($integerParam)],
+ [$this->equalTo('boolean_prop'), $this->equalTo($booleanParam)]
+ );
+
+ $this->expr->expects($this->once())
+ ->method('eq')
+ ->with($this->equalTo('id'), $this->equalTo($idParam));
+
+
+ $this->mapper->update($entity);
+ }
+
+ /**
+ *
+ */
+ public function testGetParameterTypeForProperty() {
+ $entity = new QBTestEntity();
+
+ $intType = $this->mapper->getParameterTypeForPropertyForTest($entity, 'intProp');
+ $this->assertEquals(IQueryBuilder::PARAM_INT, $intType, 'Int type property mapping incorrect');
+
+ $integerType = $this->mapper->getParameterTypeForPropertyForTest($entity, 'integerProp');
+ $this->assertEquals(IQueryBuilder::PARAM_INT, $integerType, 'Integer type property mapping incorrect');
+
+ $boolType = $this->mapper->getParameterTypeForPropertyForTest($entity, 'boolProp');
+ $this->assertEquals(IQueryBuilder::PARAM_BOOL, $boolType, 'Bool type property mapping incorrect');
+
+ $booleanType = $this->mapper->getParameterTypeForPropertyForTest($entity, 'booleanProp');
+ $this->assertEquals(IQueryBuilder::PARAM_BOOL, $booleanType, 'Boolean type property mapping incorrect');
+
+ $stringType = $this->mapper->getParameterTypeForPropertyForTest($entity, 'stringProp');
+ $this->assertEquals(IQueryBuilder::PARAM_STR, $stringType, 'String type property mapping incorrect');
+
+ $unknownType = $this->mapper->getParameterTypeForPropertyForTest($entity, 'someProp');
+ $this->assertEquals(IQueryBuilder::PARAM_STR, $unknownType, 'Unknown type property mapping incorrect');
+ }
+} \ No newline at end of file