Add tests
This commit is contained in:
parent
f273c27e3b
commit
7c0c102f9f
3 changed files with 244 additions and 23 deletions
|
@ -30,7 +30,7 @@ use Friendica\Security\PermissionSet\Depository\PermissionSet as PermissionSetDe
|
||||||
use Friendica\Security\PermissionSet\Entity\PermissionSet;
|
use Friendica\Security\PermissionSet\Entity\PermissionSet;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Custom profile field model class.
|
* Custom profile field entity class.
|
||||||
*
|
*
|
||||||
* Custom profile fields are user-created arbitrary profile fields that can be assigned a permission set to restrict its
|
* Custom profile fields are user-created arbitrary profile fields that can be assigned a permission set to restrict its
|
||||||
* display to specific Friendica contacts as it requires magic authentication to work.
|
* display to specific Friendica contacts as it requires magic authentication to work.
|
||||||
|
@ -68,26 +68,19 @@ class ProfileField extends BaseEntity
|
||||||
/** @var \DateTime */
|
/** @var \DateTime */
|
||||||
protected $edited;
|
protected $edited;
|
||||||
|
|
||||||
/**
|
|
||||||
* @throws UnexpectedPermissionSetException In case no Permission Set can be retrieved
|
|
||||||
*/
|
|
||||||
public function __construct(PermissionSetDepository $permissionSetDepository, int $uid, int $order, int $permissionSetId, string $label, string $value, \DateTime $created, \DateTime $edited, int $id = null, PermissionSet $permissionSet = null)
|
public function __construct(PermissionSetDepository $permissionSetDepository, int $uid, int $order, int $permissionSetId, string $label, string $value, \DateTime $created, \DateTime $edited, int $id = null, PermissionSet $permissionSet = null)
|
||||||
{
|
{
|
||||||
$this->permissionSetDepository = $permissionSetDepository;
|
$this->permissionSetDepository = $permissionSetDepository;
|
||||||
$this->permissionSet = $permissionSet;
|
$this->permissionSet = $permissionSet;
|
||||||
|
|
||||||
$this->uid = $uid;
|
$this->uid = $uid;
|
||||||
$this->order = $order;
|
$this->order = $order;
|
||||||
$this->permissionSetId = $permissionSetId ?? ($permissionSet ? $permissionSet->id : null);
|
$this->permissionSetId = $permissionSetId;
|
||||||
$this->label = $label;
|
$this->label = $label;
|
||||||
$this->value = $value;
|
$this->value = $value;
|
||||||
$this->created = $created;
|
$this->created = $created;
|
||||||
$this->edited = $edited;
|
$this->edited = $edited;
|
||||||
$this->id = $id;
|
$this->id = $id;
|
||||||
|
|
||||||
if (is_null($this->permissionSetId)) {
|
|
||||||
throw new UnexpectedPermissionSetException('Either set the permission set ID or the permission set itself');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -134,11 +127,11 @@ class ProfileField extends BaseEntity
|
||||||
*/
|
*/
|
||||||
public function update(string $value, int $order, PermissionSet $permissionSet)
|
public function update(string $value, int $order, PermissionSet $permissionSet)
|
||||||
{
|
{
|
||||||
$this->value = $value;
|
$this->value = $value;
|
||||||
$this->order = $order;
|
$this->order = $order;
|
||||||
$this->permissionSet = $permissionSet;
|
$this->permissionSet = $permissionSet;
|
||||||
$this->permissionSetId = $permissionSet->id;
|
$this->permissionSetId = $permissionSet->id;
|
||||||
$this->edited = new \DateTime('now', new \DateTimeZone('UTC'));
|
$this->edited = new \DateTime('now', new \DateTimeZone('UTC'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
namespace Friendica\Profile\ProfileField\Factory;
|
namespace Friendica\Profile\ProfileField\Factory;
|
||||||
|
|
||||||
use Friendica\BaseFactory;
|
use Friendica\BaseFactory;
|
||||||
|
use Friendica\Profile\ProfileField\Exception\UnexpectedPermissionSetException;
|
||||||
use Friendica\Security\PermissionSet\Depository\PermissionSet as PermissionSetDepository;
|
use Friendica\Security\PermissionSet\Depository\PermissionSet as PermissionSetDepository;
|
||||||
use Friendica\Profile\ProfileField\Entity;
|
use Friendica\Profile\ProfileField\Entity;
|
||||||
use Friendica\Capabilities\ICanCreateFromTableRow;
|
use Friendica\Capabilities\ICanCreateFromTableRow;
|
||||||
|
@ -45,16 +46,20 @@ class ProfileField extends BaseFactory implements ICanCreateFromTableRow
|
||||||
*/
|
*/
|
||||||
public function createFromTableRow(array $row, PermissionSet $permissionSet = null): Entity\ProfileField
|
public function createFromTableRow(array $row, PermissionSet $permissionSet = null): Entity\ProfileField
|
||||||
{
|
{
|
||||||
|
if (empty($permissionSet) && empty($row['psid'])) {
|
||||||
|
throw new UnexpectedPermissionSetException('Either set the permission set ID or the permission set itself');
|
||||||
|
}
|
||||||
|
|
||||||
return new Entity\ProfileField(
|
return new Entity\ProfileField(
|
||||||
$this->permissionSetDepository,
|
$this->permissionSetDepository,
|
||||||
$row['uid'],
|
$row['uid'],
|
||||||
$row['order'],
|
$row['order'],
|
||||||
$row['psid'],
|
$row['psid'] ?? $permissionSet->id,
|
||||||
$row['label'],
|
$row['label'],
|
||||||
$row['value'],
|
$row['value'],
|
||||||
new \DateTime($row['created'] ?? 'now', new \DateTimeZone('UTC')),
|
new \DateTime($row['created'] ?? 'now', new \DateTimeZone('UTC')),
|
||||||
new \DateTime($row['edited'] ?? 'now', new \DateTimeZone('UTC')),
|
new \DateTime($row['edited'] ?? 'now', new \DateTimeZone('UTC')),
|
||||||
$row['id'],
|
$row['id'] ?? null,
|
||||||
$permissionSet
|
$permissionSet
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
223
tests/src/Profile/ProfileField/Entity/ProfileFieldTest.php
Normal file
223
tests/src/Profile/ProfileField/Entity/ProfileFieldTest.php
Normal file
|
@ -0,0 +1,223 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Test\src\Profile\ProfileField\Entity;
|
||||||
|
|
||||||
|
use Friendica\Network\HTTPException\NotFoundException;
|
||||||
|
use Friendica\Profile\ProfileField\Entity\ProfileField;
|
||||||
|
use Friendica\Profile\ProfileField\Exception\ProfileFieldNotFoundException;
|
||||||
|
use Friendica\Profile\ProfileField\Exception\UnexpectedPermissionSetException;
|
||||||
|
use Friendica\Profile\ProfileField\Factory\ProfileField as ProfileFieldFactory;
|
||||||
|
use Friendica\Security\PermissionSet\Depository\PermissionSet as PermissionSetDepository;
|
||||||
|
use Friendica\Security\PermissionSet\Factory\PermissionSet as PermissionSetFactory;
|
||||||
|
use Friendica\Test\MockedTest;
|
||||||
|
use Friendica\Util\ACLFormatter;
|
||||||
|
use Friendica\Util\DateTimeFormat;
|
||||||
|
use Friendica\Util\Logger\VoidLogger;
|
||||||
|
use Mockery\MockInterface;
|
||||||
|
|
||||||
|
class ProfileFieldTest extends MockedTest
|
||||||
|
{
|
||||||
|
/** @var MockInterface|PermissionSetDepository */
|
||||||
|
protected $permissionSetDepository;
|
||||||
|
/** @var ProfileFieldFactory */
|
||||||
|
protected $profileFieldFactory;
|
||||||
|
/** @var PermissionSetFactory */
|
||||||
|
protected $permissionSetFactory;
|
||||||
|
|
||||||
|
protected function setUp(): void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->permissionSetDepository = \Mockery::mock(PermissionSetDepository::class);
|
||||||
|
$this->profileFieldFactory = new ProfileFieldFactory(new VoidLogger(), $this->permissionSetDepository);
|
||||||
|
$this->permissionSetFactory = new PermissionSetFactory(new VoidLogger(), new ACLFormatter());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dataEntity()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'default' => [
|
||||||
|
'uid' => 23,
|
||||||
|
'order' => 1,
|
||||||
|
'psid' => 2,
|
||||||
|
'label' => 'test',
|
||||||
|
'value' => 'more',
|
||||||
|
'created' => new \DateTime('2021-10-10T21:12:00.000000+0000', new \DateTimeZone('UTC')),
|
||||||
|
'edited' => new \DateTime('2021-10-10T21:12:00.000000+0000', new \DateTimeZone('UTC')),
|
||||||
|
],
|
||||||
|
'withId' => [
|
||||||
|
'uid' => 23,
|
||||||
|
'order' => 1,
|
||||||
|
'psid' => 2,
|
||||||
|
'label' => 'test',
|
||||||
|
'value' => 'more',
|
||||||
|
'created' => new \DateTime('2021-10-10T21:12:00.000000+0000', new \DateTimeZone('UTC')),
|
||||||
|
'edited' => new \DateTime('2021-10-10T21:12:00.000000+0000', new \DateTimeZone('UTC')),
|
||||||
|
'id' => 54,
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testEntity(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$entity = new ProfileField($this->permissionSetDepository, $uid, $order, $psid, $label, $value, $created, $edited, $id);
|
||||||
|
|
||||||
|
self::assertEquals($uid, $entity->uid);
|
||||||
|
self::assertEquals($order, $entity->order);
|
||||||
|
self::assertEquals($psid, $entity->permissionSetId);
|
||||||
|
self::assertEquals($label, $entity->label);
|
||||||
|
self::assertEquals($value, $entity->value);
|
||||||
|
self::assertEquals($created, $entity->created);
|
||||||
|
self::assertEquals($edited, $entity->edited);
|
||||||
|
self::assertEquals($id, $entity->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testUpdate(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$permissionSet = $this->permissionSetFactory->createFromTableRow(['uid' => 2, 'id' => $psid]);
|
||||||
|
|
||||||
|
$entity = $this->profileFieldFactory->createFromTableRow([
|
||||||
|
'uid' => $uid,
|
||||||
|
'order' => $order,
|
||||||
|
'psid' => $psid,
|
||||||
|
'label' => $label,
|
||||||
|
'value' => $value,
|
||||||
|
'created' => $created->format(DateTimeFormat::MYSQL),
|
||||||
|
'edited' => $edited->format(DateTimeFormat::MYSQL),
|
||||||
|
'id' => $id,
|
||||||
|
], $permissionSet);
|
||||||
|
|
||||||
|
$permissionSetNew = $this->permissionSetFactory->createFromTableRow(['uid' => 2, 'allow_cid' => '<1>',
|
||||||
|
'id' => 23]);
|
||||||
|
|
||||||
|
$entity->update('updatedValue', 2345, $permissionSetNew);
|
||||||
|
|
||||||
|
self::assertEquals($uid, $entity->uid);
|
||||||
|
self::assertEquals(2345, $entity->order);
|
||||||
|
self::assertEquals(23, $entity->permissionSetId);
|
||||||
|
self::assertEquals($label, $entity->label);
|
||||||
|
self::assertEquals('updatedValue', $entity->value);
|
||||||
|
self::assertEquals($created, $entity->created);
|
||||||
|
self::assertGreaterThan($edited, $entity->edited);
|
||||||
|
self::assertEquals($id, $entity->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testSetOrder(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$permissionSet = $this->permissionSetFactory->createFromTableRow(['uid' => 2, 'id' => $psid]);
|
||||||
|
|
||||||
|
$entity = $this->profileFieldFactory->createFromTableRow([
|
||||||
|
'uid' => $uid,
|
||||||
|
'order' => $order,
|
||||||
|
'psid' => $psid,
|
||||||
|
'label' => $label,
|
||||||
|
'value' => $value,
|
||||||
|
'created' => $created->format(DateTimeFormat::MYSQL),
|
||||||
|
'edited' => $edited->format(DateTimeFormat::MYSQL),
|
||||||
|
'id' => $id,
|
||||||
|
], $permissionSet);
|
||||||
|
|
||||||
|
$entity->setOrder(2345);
|
||||||
|
|
||||||
|
self::assertEquals($uid, $entity->uid);
|
||||||
|
self::assertEquals(2345, $entity->order);
|
||||||
|
self::assertEquals($psid, $entity->permissionSetId);
|
||||||
|
self::assertEquals($label, $entity->label);
|
||||||
|
self::assertEquals($value, $entity->value);
|
||||||
|
self::assertEquals($created, $entity->created);
|
||||||
|
self::assertGreaterThan($edited, $entity->edited);
|
||||||
|
self::assertEquals($id, $entity->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the exception because of a wrong property
|
||||||
|
*
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testWrongGet(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$entity = new ProfileField($this->permissionSetDepository, $uid, $order, $psid, $label, $value, $created, $edited, $id);
|
||||||
|
|
||||||
|
self::expectException(ProfileFieldNotFoundException::class);
|
||||||
|
$entity->wrong;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test gathering the permissionset
|
||||||
|
*
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testPermissionSet(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$entity = new ProfileField($this->permissionSetDepository, $uid, $order, $psid, $label, $value, $created, $edited, $id);
|
||||||
|
$permissionSet = $this->permissionSetFactory->createFromTableRow(['uid' => $uid, 'id' => $psid]);
|
||||||
|
|
||||||
|
$this->permissionSetDepository->shouldReceive('selectOneById')->with($psid)->andReturns($permissionSet);
|
||||||
|
|
||||||
|
self::assertEquals($psid, $entity->permissionSet->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the exception because of incompatible user id
|
||||||
|
*
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testWrongPermissionSet(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$entity = new ProfileField($this->permissionSetDepository, $uid, $order, $psid, $label, $value, $created, $edited, $id);
|
||||||
|
$permissionSet = $this->permissionSetFactory->createFromTableRow(['uid' => 12345, 'id' => $psid]);
|
||||||
|
|
||||||
|
$this->permissionSetDepository->shouldReceive('selectOneById')->with($psid)->andReturns($permissionSet);
|
||||||
|
|
||||||
|
self::expectException(UnexpectedPermissionSetException::class);
|
||||||
|
self::expectExceptionMessage(sprintf('PermissionSet %d (user-id: %d) for ProfileField %d (user-id: %d) is invalid.', $psid, 12345, $id, $uid));
|
||||||
|
$entity->permissionSet;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the exception because of missing permission set
|
||||||
|
*
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testMissingPermissionSet(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
$entity = new ProfileField($this->permissionSetDepository, $uid, $order, $psid, $label, $value, $created, $edited, $id);
|
||||||
|
|
||||||
|
$this->permissionSetDepository->shouldReceive('selectOneById')->with($psid)
|
||||||
|
->andThrow(new NotFoundException('test'));
|
||||||
|
|
||||||
|
self::expectException(UnexpectedPermissionSetException::class);
|
||||||
|
self::expectExceptionMessage(sprintf('No PermissionSet found for ProfileField %d (user-id: %d).', $id, $uid));
|
||||||
|
$entity->permissionSet;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the exception because the factory cannot find a permissionSet ID, nor the permissionSet itself
|
||||||
|
*
|
||||||
|
* @dataProvider dataEntity
|
||||||
|
*/
|
||||||
|
public function testMissingPermissionFactory(int $uid, int $order, int $psid, string $label, string $value, \DateTime $created, \DateTime $edited, $id = null)
|
||||||
|
{
|
||||||
|
self::expectException(UnexpectedPermissionSetException::class);
|
||||||
|
self::expectExceptionMessage('Either set the permission set ID or the permission set itself');
|
||||||
|
|
||||||
|
$entity = $this->profileFieldFactory->createFromTableRow([
|
||||||
|
'uid' => $uid,
|
||||||
|
'order' => $order,
|
||||||
|
'label' => $label,
|
||||||
|
'value' => $value,
|
||||||
|
'created' => $created->format(DateTimeFormat::MYSQL),
|
||||||
|
'edited' => $edited->format(DateTimeFormat::MYSQL),
|
||||||
|
'id' => $id,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue