diff --git a/lib/public/AppFramework/Db/Entity.php b/lib/public/AppFramework/Db/Entity.php index 091b90257b40d..8bd537211fcc5 100644 --- a/lib/public/AppFramework/Db/Entity.php +++ b/lib/public/AppFramework/Db/Entity.php @@ -87,7 +87,7 @@ public function getFieldTypes() { return $this->_fieldTypes; } - + /** * Marks the entity as clean needed for setting the id after the insertion * @since 7.0.0 @@ -115,7 +115,7 @@ protected function setter($name, $args) { $this->$name = $args[0]; } else { - throw new \BadFunctionCallException($name . + throw new \BadFunctionCallException($name . ' is not a valid attribute'); } } @@ -129,7 +129,7 @@ protected function getter($name) { if(property_exists($this, $name)){ return $this->$name; } else { - throw new \BadFunctionCallException($name . + throw new \BadFunctionCallException($name . ' is not a valid attribute'); } } @@ -137,7 +137,7 @@ protected function getter($name) { /** * Each time a setter is called, push the part after set - * into an array: for instance setId will save Id in the + * into an array: for instance setId will save Id in the * updated fields array so it can be easily used to create the * getter method * @since 7.0.0 @@ -147,7 +147,7 @@ public function __call($methodName, $args) { $this->setter(lcfirst(substr($methodName, 3)), $args); } elseif (strpos($methodName, 'get') === 0) { return $this->getter(lcfirst(substr($methodName, 3))); - } elseif (strpos($methodName, 'is') === 0) { + } elseif ($this->isGetterForBoolProperty($methodName)) { return $this->getter(lcfirst(substr($methodName, 2))); } else { throw new \BadFunctionCallException($methodName . @@ -156,6 +156,18 @@ public function __call($methodName, $args) { } + /** + * @param string $methodName + * @return bool + * @since 18.0.0 + */ + protected function isGetterForBoolProperty(string $methodName): bool { + if (strpos($methodName, 'is') === 0) { + $fieldName = lcfirst(substr($methodName, 2)); + return isset($this->_fieldTypes[$fieldName]) && strpos($this->_fieldTypes[$fieldName], 'bool') === 0; + } + return false; + } /** * Mark am attribute as updated @@ -168,7 +180,7 @@ protected function markFieldUpdated($attribute){ /** - * Transform a database columnname to a property + * Transform a database columnname to a property * @param string $columnName the name of the column * @return string the property name * @since 7.0.0 diff --git a/tests/lib/AppFramework/Db/EntityTest.php b/tests/lib/AppFramework/Db/EntityTest.php index fd075a9300dfe..a49440949e3af 100644 --- a/tests/lib/AppFramework/Db/EntityTest.php +++ b/tests/lib/AppFramework/Db/EntityTest.php @@ -25,6 +25,7 @@ use OCP\AppFramework\Db\Entity; +use PHPUnit\Framework\Constraint\IsType; /** * @method integer getId() @@ -37,18 +38,28 @@ * @method void setEmail(string $email) * @method string getPreName() * @method void setPreName(string $preName) + * @method bool getTrueOrFalse() + * @method bool isTrueOrFalse() + * @method void setTrueOrFalse(bool $trueOrFalse) + * @method bool getAnotherBool() + * @method bool isAnotherBool() + * @method void setAnotherBool(bool $anotherBool) */ class TestEntity extends Entity { protected $name; protected $email; protected $testId; protected $preName; + protected $trueOrFalse; + protected $anotherBool; - public function __construct($name=null){ + public function __construct($name = null) { $this->addType('testId', 'integer'); + $this->addType('trueOrFalse', 'bool'); + $this->addType('anotherBool', 'boolean'); $this->name = $name; } -}; +} class EntityTest extends \Test\TestCase { @@ -72,7 +83,7 @@ public function testResetUpdatedFields(){ public function testFromRow(){ $row = array( - 'pre_name' => 'john', + 'pre_name' => 'john', 'email' => 'john@something.com' ); $this->entity = TestEntity::fromRow($row); @@ -92,21 +103,21 @@ public function testGetSetId(){ public function testColumnToPropertyNoReplacement(){ $column = 'my'; - $this->assertEquals('my', + $this->assertEquals('my', $this->entity->columnToProperty($column)); } public function testColumnToProperty(){ $column = 'my_attribute'; - $this->assertEquals('myAttribute', + $this->assertEquals('myAttribute', $this->entity->columnToProperty($column)); } public function testPropertyToColumnNoReplacement(){ $property = 'my'; - $this->assertEquals('my', + $this->assertEquals('my', $this->entity->propertyToColumn($property)); } @@ -136,7 +147,6 @@ public function testGetterShouldFailIfAttributeNotDefined(){ /** * @expectedException \BadFunctionCallException */ - public function testSetterShouldFailIfAttributeNotDefined(){ $this->entity->setTest(); } @@ -207,7 +217,9 @@ public function testGetFieldTypes() { $entity = new TestEntity(); $this->assertEquals(array( 'id' => 'integer', - 'testId' => 'integer' + 'testId' => 'integer', + 'trueOrFalse' => 'bool', + 'anotherBool' => 'boolean', ), $entity->getFieldTypes()); } @@ -225,5 +237,20 @@ public function testFieldsNotMarkedUpdatedIfNothingChanges() { $this->assertEquals(0, count($entity->getUpdatedFields())); } + public function testIsGetter() { + $entity = new TestEntity(); + $entity->setTrueOrFalse(false); + $entity->setAnotherBool(false); + $this->assertThat($entity->isTrueOrFalse(), new IsType(IsType::TYPE_BOOL)); + $this->assertThat($entity->isAnotherBool(), new IsType(IsType::TYPE_BOOL)); + } + /** + * @expectedException BadFunctionCallException + */ + public function testIsGetterShoudFailForOtherType() { + $entity = new TestEntity(); + $entity->setName('hello'); + $this->assertThat($entity->isName(), new IsType(IsType::TYPE_BOOL)); + } }