2021-01-09 12:38:06 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace ShlinkioTest\Shlink\Rest\ApiKey;
|
|
|
|
|
|
|
|
use Happyr\DoctrineSpecification\Spec;
|
|
|
|
use Happyr\DoctrineSpecification\Specification\Specification;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
use Shlinkio\Shlink\Core\ShortUrl\Spec\BelongsToApiKey;
|
|
|
|
use Shlinkio\Shlink\Core\ShortUrl\Spec\BelongsToApiKeyInlined;
|
|
|
|
use Shlinkio\Shlink\Core\ShortUrl\Spec\BelongsToDomain;
|
|
|
|
use Shlinkio\Shlink\Core\ShortUrl\Spec\BelongsToDomainInlined;
|
|
|
|
use Shlinkio\Shlink\Rest\ApiKey\Role;
|
|
|
|
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
|
|
|
use Shlinkio\Shlink\Rest\Entity\ApiKeyRole;
|
|
|
|
|
|
|
|
class RoleTest extends TestCase
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideRoles
|
|
|
|
*/
|
|
|
|
public function returnsExpectedSpec(ApiKeyRole $apiKeyRole, bool $inlined, Specification $expected): void
|
|
|
|
{
|
|
|
|
self::assertEquals($expected, Role::toSpec($apiKeyRole, $inlined));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function provideRoles(): iterable
|
|
|
|
{
|
2021-03-14 09:59:35 +01:00
|
|
|
$apiKey = ApiKey::create();
|
2021-01-09 12:38:06 +01:00
|
|
|
|
|
|
|
yield 'inline invalid role' => [new ApiKeyRole('invalid', [], $apiKey), true, Spec::andX()];
|
|
|
|
yield 'not inline invalid role' => [new ApiKeyRole('invalid', [], $apiKey), false, Spec::andX()];
|
|
|
|
yield 'inline author role' => [
|
|
|
|
new ApiKeyRole(Role::AUTHORED_SHORT_URLS, [], $apiKey),
|
|
|
|
true,
|
2021-02-26 20:27:41 +01:00
|
|
|
Spec::andX(new BelongsToApiKeyInlined($apiKey)),
|
2021-01-09 12:38:06 +01:00
|
|
|
];
|
|
|
|
yield 'not inline author role' => [
|
|
|
|
new ApiKeyRole(Role::AUTHORED_SHORT_URLS, [], $apiKey),
|
|
|
|
false,
|
|
|
|
new BelongsToApiKey($apiKey),
|
|
|
|
];
|
|
|
|
yield 'inline domain role' => [
|
|
|
|
new ApiKeyRole(Role::DOMAIN_SPECIFIC, ['domain_id' => '123'], $apiKey),
|
|
|
|
true,
|
2021-02-26 20:27:41 +01:00
|
|
|
Spec::andX(new BelongsToDomainInlined('123')),
|
2021-01-09 12:38:06 +01:00
|
|
|
];
|
|
|
|
yield 'not inline domain role' => [
|
|
|
|
new ApiKeyRole(Role::DOMAIN_SPECIFIC, ['domain_id' => '456'], $apiKey),
|
|
|
|
false,
|
|
|
|
new BelongsToDomain('456'),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
2021-01-11 17:01:01 +01:00
|
|
|
* @dataProvider provideMetasWithDomainId
|
2021-01-09 12:38:06 +01:00
|
|
|
*/
|
|
|
|
public function getsExpectedDomainIdFromMeta(array $meta, string $expectedDomainId): void
|
|
|
|
{
|
|
|
|
self::assertEquals($expectedDomainId, Role::domainIdFromMeta($meta));
|
|
|
|
}
|
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
public function provideMetasWithDomainId(): iterable
|
2021-01-09 12:38:06 +01:00
|
|
|
{
|
|
|
|
yield 'empty meta' => [[], '-1'];
|
|
|
|
yield 'meta without domain_id' => [['foo' => 'bar'], '-1'];
|
|
|
|
yield 'meta with domain_id' => [['domain_id' => '123'], '123'];
|
|
|
|
}
|
2021-01-11 17:01:01 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideMetasWithAuthority
|
|
|
|
*/
|
|
|
|
public function getsExpectedAuthorityFromMeta(array $meta, string $expectedAuthority): void
|
|
|
|
{
|
|
|
|
self::assertEquals($expectedAuthority, Role::domainAuthorityFromMeta($meta));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function provideMetasWithAuthority(): iterable
|
|
|
|
{
|
|
|
|
yield 'empty meta' => [[], ''];
|
|
|
|
yield 'meta without authority' => [['foo' => 'bar'], ''];
|
|
|
|
yield 'meta with authority' => [['authority' => 'example.com'], 'example.com'];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideRoleNames
|
|
|
|
*/
|
|
|
|
public function getsExpectedRoleFriendlyName(string $roleName, string $expectedFriendlyName): void
|
|
|
|
{
|
|
|
|
self::assertEquals($expectedFriendlyName, Role::toFriendlyName($roleName));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function provideRoleNames(): iterable
|
|
|
|
{
|
|
|
|
yield 'unknown' => ['unknown', ''];
|
|
|
|
yield Role::AUTHORED_SHORT_URLS => [Role::AUTHORED_SHORT_URLS, 'Author only'];
|
|
|
|
yield Role::DOMAIN_SPECIFIC => [Role::DOMAIN_SPECIFIC, 'Domain only'];
|
|
|
|
}
|
2021-01-09 12:38:06 +01:00
|
|
|
}
|