2014-04-19 12:56:16 +00: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 16:40:34 +00:00
|
|
|
namespace Test\AppFramework\Db;
|
|
|
|
|
|
|
|
|
|
|
|
use OCP\AppFramework\Db\Entity;
|
2014-04-19 12:56:16 +00:00
|
|
|
|
|
|
|
|
2014-04-19 13:25:36 +00: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 00:55:21 +00:00
|
|
|
* @method void setEmail(string $email)
|
2014-04-19 13:25:36 +00:00
|
|
|
* @method string getPreName()
|
|
|
|
* @method void setPreName(string $preName)
|
|
|
|
*/
|
2014-04-19 12:56:16 +00:00
|
|
|
class TestEntity extends Entity {
|
2014-08-27 11:28:04 +00:00
|
|
|
protected $name;
|
|
|
|
protected $email;
|
|
|
|
protected $testId;
|
|
|
|
protected $preName;
|
2014-04-19 12:56:16 +00:00
|
|
|
|
2014-04-23 11:43:17 +00:00
|
|
|
public function __construct($name=null){
|
2018-01-24 17:10:16 +00:00
|
|
|
$this->addType('testId', 'integer');
|
2014-04-23 11:43:17 +00:00
|
|
|
$this->name = $name;
|
2014-04-19 12:56:16 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2014-11-10 22:30:38 +00:00
|
|
|
class EntityTest extends \Test\TestCase {
|
2014-04-19 12:56:16 +00:00
|
|
|
|
|
|
|
private $entity;
|
|
|
|
|
|
|
|
protected function setUp(){
|
2014-11-10 22:30:38 +00:00
|
|
|
parent::setUp();
|
2014-04-19 12:56:16 +00: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(
|
|
|
|
'pre_name' => 'john',
|
|
|
|
'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';
|
|
|
|
$this->assertEquals('my',
|
|
|
|
$this->entity->columnToProperty($column));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testColumnToProperty(){
|
|
|
|
$column = 'my_attribute';
|
|
|
|
$this->assertEquals('myAttribute',
|
|
|
|
$this->entity->columnToProperty($column));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testPropertyToColumnNoReplacement(){
|
|
|
|
$property = 'my';
|
|
|
|
$this->assertEquals('my',
|
|
|
|
$this->entity->propertyToColumn($property));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testSetterMarksFieldUpdated(){
|
|
|
|
$this->entity->setId(3);
|
|
|
|
|
|
|
|
$this->assertContains('id', $this->entity->getUpdatedFields());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-01-24 17:10:16 +00:00
|
|
|
/**
|
|
|
|
* @expectedException \BadFunctionCallException
|
|
|
|
*/
|
2014-04-19 12:56:16 +00:00
|
|
|
public function testCallShouldOnlyWorkForGetterSetter(){
|
|
|
|
$this->entity->something();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-01-24 17:10:16 +00:00
|
|
|
/**
|
|
|
|
* @expectedException \BadFunctionCallException
|
|
|
|
*/
|
2014-04-19 12:56:16 +00:00
|
|
|
public function testGetterShouldFailIfAttributeNotDefined(){
|
|
|
|
$this->entity->getTest();
|
|
|
|
}
|
|
|
|
|
2018-01-24 17:10:16 +00:00
|
|
|
/**
|
|
|
|
* @expectedException \BadFunctionCallException
|
|
|
|
*/
|
2014-04-19 12:56:16 +00:00
|
|
|
|
|
|
|
public function testSetterShouldFailIfAttributeNotDefined(){
|
|
|
|
$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',
|
|
|
|
'testId' => 'integer'
|
|
|
|
), $entity->getFieldTypes());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testGetItInt() {
|
|
|
|
$entity = new TestEntity();
|
|
|
|
$entity->setId(3);
|
|
|
|
$this->assertEquals('integer', gettype($entity->getId()));
|
|
|
|
}
|
|
|
|
|
2014-04-23 11:43:17 +00:00
|
|
|
|
|
|
|
public function testFieldsNotMarkedUpdatedIfNothingChanges() {
|
|
|
|
$entity = new TestEntity('hey');
|
|
|
|
$entity->setName('hey');
|
|
|
|
$this->assertEquals(0, count($entity->getUpdatedFields()));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-08-27 11:28:04 +00:00
|
|
|
}
|