2014-04-19 16:56:16 +04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ownCloud - App Framework
|
|
|
|
*
|
|
|
|
* @author Bernhard Posselt
|
|
|
|
* @copyright 2012 Bernhard Posselt dev@bernhard-posselt.com
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library 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 library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-05-18 19:40:34 +03:00
|
|
|
namespace Test\AppFramework\Db;
|
|
|
|
|
|
|
|
|
|
|
|
use OCP\AppFramework\Db\Entity;
|
2019-11-14 21:57:43 +03:00
|
|
|
use PHPUnit\Framework\Constraint\IsType;
|
2014-04-19 16:56:16 +04:00
|
|
|
|
2014-04-19 17:25:36 +04:00
|
|
|
/**
|
|
|
|
* @method integer getId()
|
|
|
|
* @method void setId(integer $id)
|
|
|
|
* @method integer getTestId()
|
|
|
|
* @method void setTestId(integer $id)
|
|
|
|
* @method string getName()
|
|
|
|
* @method void setName(string $name)
|
|
|
|
* @method string getEmail()
|
2014-04-20 04:55:21 +04:00
|
|
|
* @method void setEmail(string $email)
|
2014-04-19 17:25:36 +04:00
|
|
|
* @method string getPreName()
|
|
|
|
* @method void setPreName(string $preName)
|
2019-11-14 21:57:43 +03:00
|
|
|
* @method bool getTrueOrFalse()
|
|
|
|
* @method bool isTrueOrFalse()
|
|
|
|
* @method void setTrueOrFalse(bool $trueOrFalse)
|
|
|
|
* @method bool getAnotherBool()
|
|
|
|
* @method bool isAnotherBool()
|
|
|
|
* @method void setAnotherBool(bool $anotherBool)
|
2014-04-19 17:25:36 +04:00
|
|
|
*/
|
2014-04-19 16:56:16 +04:00
|
|
|
class TestEntity extends Entity {
|
2014-08-27 15:28:04 +04:00
|
|
|
protected $name;
|
|
|
|
protected $email;
|
|
|
|
protected $testId;
|
|
|
|
protected $preName;
|
2019-11-14 21:57:43 +03:00
|
|
|
protected $trueOrFalse;
|
|
|
|
protected $anotherBool;
|
2014-04-19 16:56:16 +04:00
|
|
|
|
2019-11-14 21:57:43 +03:00
|
|
|
public function __construct($name = null) {
|
2018-01-24 20:10:16 +03:00
|
|
|
$this->addType('testId', 'integer');
|
2019-11-14 21:57:43 +03:00
|
|
|
$this->addType('trueOrFalse', 'bool');
|
|
|
|
$this->addType('anotherBool', 'boolean');
|
2014-04-23 15:43:17 +04:00
|
|
|
$this->name = $name;
|
2014-04-19 16:56:16 +04:00
|
|
|
}
|
2019-11-14 21:57:43 +03:00
|
|
|
}
|
2014-04-19 16:56:16 +04:00
|
|
|
|
|
|
|
|
2014-11-11 01:30:38 +03:00
|
|
|
class EntityTest extends \Test\TestCase {
|
2014-04-19 16:56:16 +04:00
|
|
|
|
|
|
|
private $entity;
|
|
|
|
|
2019-11-21 18:40:38 +03:00
|
|
|
protected function setUp(): void {
|
2014-11-11 01:30:38 +03:00
|
|
|
parent::setUp();
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity = new TestEntity();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testResetUpdatedFields(){
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setId(3);
|
|
|
|
$entity->resetUpdatedFields();
|
|
|
|
|
|
|
|
$this->assertEquals(array(), $entity->getUpdatedFields());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testFromRow(){
|
|
|
|
$row = array(
|
2019-11-14 21:57:43 +03:00
|
|
|
'pre_name' => 'john',
|
2014-04-19 16:56:16 +04:00
|
|
|
'email' => 'john@something.com'
|
|
|
|
);
|
|
|
|
$this->entity = TestEntity::fromRow($row);
|
|
|
|
|
|
|
|
$this->assertEquals($row['pre_name'], $this->entity->getPreName());
|
|
|
|
$this->assertEquals($row['email'], $this->entity->getEmail());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testGetSetId(){
|
|
|
|
$id = 3;
|
|
|
|
$this->entity->setId(3);
|
|
|
|
|
|
|
|
$this->assertEquals($id, $this->entity->getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testColumnToPropertyNoReplacement(){
|
|
|
|
$column = 'my';
|
2019-11-14 21:57:43 +03:00
|
|
|
$this->assertEquals('my',
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity->columnToProperty($column));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testColumnToProperty(){
|
|
|
|
$column = 'my_attribute';
|
2019-11-14 21:57:43 +03:00
|
|
|
$this->assertEquals('myAttribute',
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity->columnToProperty($column));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testPropertyToColumnNoReplacement(){
|
|
|
|
$property = 'my';
|
2019-11-14 21:57:43 +03:00
|
|
|
$this->assertEquals('my',
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity->propertyToColumn($property));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testSetterMarksFieldUpdated(){
|
|
|
|
$this->entity->setId(3);
|
|
|
|
|
|
|
|
$this->assertContains('id', $this->entity->getUpdatedFields());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-11-27 17:27:18 +03:00
|
|
|
|
2014-04-19 16:56:16 +04:00
|
|
|
public function testCallShouldOnlyWorkForGetterSetter(){
|
2019-11-27 17:27:18 +03:00
|
|
|
$this->expectException(\BadFunctionCallException::class);
|
|
|
|
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity->something();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-11-27 17:27:18 +03:00
|
|
|
|
2014-04-19 16:56:16 +04:00
|
|
|
public function testGetterShouldFailIfAttributeNotDefined(){
|
2019-11-27 17:27:18 +03:00
|
|
|
$this->expectException(\BadFunctionCallException::class);
|
|
|
|
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity->getTest();
|
|
|
|
}
|
|
|
|
|
2019-11-27 17:27:18 +03:00
|
|
|
|
2014-04-19 16:56:16 +04:00
|
|
|
public function testSetterShouldFailIfAttributeNotDefined(){
|
2019-11-27 17:27:18 +03:00
|
|
|
$this->expectException(\BadFunctionCallException::class);
|
|
|
|
|
2014-04-19 16:56:16 +04:00
|
|
|
$this->entity->setTest();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testFromRowShouldNotAssignEmptyArray(){
|
|
|
|
$row = array();
|
|
|
|
$entity2 = new TestEntity();
|
|
|
|
|
|
|
|
$this->entity = TestEntity::fromRow($row);
|
|
|
|
$this->assertEquals($entity2, $this->entity);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testIdGetsConvertedToInt(){
|
|
|
|
$row = array('id' => '4');
|
|
|
|
|
|
|
|
$this->entity = TestEntity::fromRow($row);
|
|
|
|
$this->assertSame(4, $this->entity->getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testSetType(){
|
|
|
|
$row = array('testId' => '4');
|
|
|
|
|
|
|
|
$this->entity = TestEntity::fromRow($row);
|
|
|
|
$this->assertSame(4, $this->entity->getTestId());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testFromParams(){
|
|
|
|
$params = array(
|
|
|
|
'testId' => 4,
|
|
|
|
'email' => 'john@doe'
|
|
|
|
);
|
|
|
|
|
|
|
|
$entity = TestEntity::fromParams($params);
|
|
|
|
|
|
|
|
$this->assertEquals($params['testId'], $entity->getTestId());
|
|
|
|
$this->assertEquals($params['email'], $entity->getEmail());
|
|
|
|
$this->assertTrue($entity instanceof TestEntity);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSlugify(){
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setName('Slugify this!');
|
|
|
|
$this->assertEquals('slugify-this', $entity->slugify('name'));
|
|
|
|
$entity->setName('°!"§$%&/()=?`´ß\}][{³²#\'+~*-_.:,;<>|äöüÄÖÜSlugify this!');
|
|
|
|
$this->assertEquals('slugify-this', $entity->slugify('name'));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testSetterCasts() {
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setId('3');
|
|
|
|
$this->assertSame(3, $entity->getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testSetterDoesNotCastOnNull() {
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setId(null);
|
|
|
|
$this->assertSame(null, $entity->getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testGetFieldTypes() {
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$this->assertEquals(array(
|
|
|
|
'id' => 'integer',
|
2019-11-14 21:57:43 +03:00
|
|
|
'testId' => 'integer',
|
|
|
|
'trueOrFalse' => 'bool',
|
|
|
|
'anotherBool' => 'boolean',
|
2014-04-19 16:56:16 +04:00
|
|
|
), $entity->getFieldTypes());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testGetItInt() {
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setId(3);
|
|
|
|
$this->assertEquals('integer', gettype($entity->getId()));
|
|
|
|
}
|
|
|
|
|
2014-04-23 15:43:17 +04:00
|
|
|
|
|
|
|
public function testFieldsNotMarkedUpdatedIfNothingChanges() {
|
|
|
|
$entity = new TestEntity('hey');
|
|
|
|
$entity->setName('hey');
|
|
|
|
$this->assertEquals(0, count($entity->getUpdatedFields()));
|
|
|
|
}
|
|
|
|
|
2019-11-14 21:57:43 +03:00
|
|
|
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));
|
|
|
|
}
|
2014-04-23 15:43:17 +04:00
|
|
|
|
2019-11-27 17:27:18 +03:00
|
|
|
|
2019-11-14 21:57:43 +03:00
|
|
|
public function testIsGetterShoudFailForOtherType() {
|
2019-11-27 17:27:18 +03:00
|
|
|
$this->expectException(\BadFunctionCallException::class);
|
|
|
|
|
2019-11-14 21:57:43 +03:00
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setName('hello');
|
|
|
|
$this->assertThat($entity->isName(), new IsType(IsType::TYPE_BOOL));
|
|
|
|
}
|
2014-08-27 15:28:04 +04:00
|
|
|
}
|