2016-08-06 18:50:50 +02:00
|
|
|
<?php
|
2019-10-05 17:26:10 +02:00
|
|
|
|
2017-10-12 10:13:20 +02:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2016-08-06 18:50:50 +02:00
|
|
|
namespace ShlinkioTest\Shlink\CLI\Command\Api;
|
|
|
|
|
2017-03-24 20:34:18 +01:00
|
|
|
use PHPUnit\Framework\TestCase;
|
2020-11-02 11:50:19 +01:00
|
|
|
use Prophecy\PhpUnit\ProphecyTrait;
|
2016-08-06 18:50:50 +02:00
|
|
|
use Prophecy\Prophecy\ObjectProphecy;
|
|
|
|
use Shlinkio\Shlink\CLI\Command\Api\ListKeysCommand;
|
2021-01-11 17:01:01 +01:00
|
|
|
use Shlinkio\Shlink\Core\Entity\Domain;
|
|
|
|
use Shlinkio\Shlink\Rest\ApiKey\Model\RoleDefinition;
|
2016-08-06 18:50:50 +02:00
|
|
|
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
2019-12-29 22:27:00 +01:00
|
|
|
use Shlinkio\Shlink\Rest\Service\ApiKeyServiceInterface;
|
2016-08-06 18:50:50 +02:00
|
|
|
use Symfony\Component\Console\Application;
|
|
|
|
use Symfony\Component\Console\Tester\CommandTester;
|
|
|
|
|
|
|
|
class ListKeysCommandTest extends TestCase
|
|
|
|
{
|
2020-11-02 11:50:19 +01:00
|
|
|
use ProphecyTrait;
|
|
|
|
|
2019-12-29 22:27:00 +01:00
|
|
|
private CommandTester $commandTester;
|
|
|
|
private ObjectProphecy $apiKeyService;
|
2016-08-06 18:50:50 +02:00
|
|
|
|
2019-02-16 10:53:45 +01:00
|
|
|
public function setUp(): void
|
2016-08-06 18:50:50 +02:00
|
|
|
{
|
2019-12-29 22:27:00 +01:00
|
|
|
$this->apiKeyService = $this->prophesize(ApiKeyServiceInterface::class);
|
2018-11-18 16:02:52 +01:00
|
|
|
$command = new ListKeysCommand($this->apiKeyService->reveal());
|
2016-08-06 18:50:50 +02:00
|
|
|
$app = new Application();
|
|
|
|
$app->add($command);
|
|
|
|
$this->commandTester = new CommandTester($command);
|
|
|
|
}
|
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideKeysAndOutputs
|
|
|
|
*/
|
|
|
|
public function returnsExpectedOutput(array $keys, bool $enabledOnly, string $expected): void
|
2016-08-06 18:50:50 +02:00
|
|
|
{
|
2021-01-11 17:01:01 +01:00
|
|
|
$listKeys = $this->apiKeyService->listKeys($enabledOnly)->willReturn($keys);
|
2018-11-17 17:36:22 +01:00
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
$this->commandTester->execute(['--enabledOnly' => $enabledOnly]);
|
2018-11-17 17:36:22 +01:00
|
|
|
$output = $this->commandTester->getDisplay();
|
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
self::assertEquals($expected, $output);
|
|
|
|
$listKeys->shouldHaveBeenCalledOnce();
|
2016-08-06 18:50:50 +02:00
|
|
|
}
|
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
public function provideKeysAndOutputs(): iterable
|
2016-08-06 18:50:50 +02:00
|
|
|
{
|
2021-01-11 17:01:01 +01:00
|
|
|
yield 'all keys' => [
|
|
|
|
[ApiKey::withKey('foo'), ApiKey::withKey('bar'), ApiKey::withKey('baz')],
|
|
|
|
false,
|
|
|
|
<<<OUTPUT
|
|
|
|
+-----+------------+-----------------+-------+
|
|
|
|
| Key | Is enabled | Expiration date | Roles |
|
|
|
|
+-----+------------+-----------------+-------+
|
2021-01-11 20:23:28 +01:00
|
|
|
| foo | +++ | - | Admin |
|
|
|
|
| bar | +++ | - | Admin |
|
|
|
|
| baz | +++ | - | Admin |
|
2021-01-11 17:01:01 +01:00
|
|
|
+-----+------------+-----------------+-------+
|
2018-11-17 17:36:22 +01:00
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
OUTPUT,
|
|
|
|
];
|
|
|
|
yield 'enabled keys' => [
|
|
|
|
[ApiKey::withKey('foo')->disable(), ApiKey::withKey('bar')],
|
|
|
|
true,
|
|
|
|
<<<OUTPUT
|
|
|
|
+-----+-----------------+-------+
|
|
|
|
| Key | Expiration date | Roles |
|
|
|
|
+-----+-----------------+-------+
|
2021-01-11 20:23:28 +01:00
|
|
|
| foo | - | Admin |
|
|
|
|
| bar | - | Admin |
|
2021-01-11 17:01:01 +01:00
|
|
|
+-----+-----------------+-------+
|
|
|
|
|
|
|
|
OUTPUT,
|
|
|
|
];
|
|
|
|
yield 'with roles' => [
|
|
|
|
[
|
|
|
|
ApiKey::withKey('foo'),
|
|
|
|
$this->apiKeyWithRoles('bar', [RoleDefinition::forAuthoredShortUrls()]),
|
|
|
|
$this->apiKeyWithRoles('baz', [RoleDefinition::forDomain((new Domain('example.com'))->setId('1'))]),
|
|
|
|
ApiKey::withKey('foo2'),
|
|
|
|
$this->apiKeyWithRoles('baz2', [
|
|
|
|
RoleDefinition::forAuthoredShortUrls(),
|
|
|
|
RoleDefinition::forDomain((new Domain('example.com'))->setId('1')),
|
|
|
|
]),
|
|
|
|
ApiKey::withKey('foo3'),
|
|
|
|
],
|
|
|
|
true,
|
|
|
|
<<<OUTPUT
|
|
|
|
+------+-----------------+--------------------------+
|
|
|
|
| Key | Expiration date | Roles |
|
|
|
|
+------+-----------------+--------------------------+
|
2021-01-11 20:23:28 +01:00
|
|
|
| foo | - | Admin |
|
2021-01-11 17:01:01 +01:00
|
|
|
| bar | - | Author only |
|
|
|
|
| baz | - | Domain only: example.com |
|
2021-01-11 20:23:28 +01:00
|
|
|
| foo2 | - | Admin |
|
2021-01-11 17:01:01 +01:00
|
|
|
| baz2 | - | Author only |
|
|
|
|
| | | Domain only: example.com |
|
2021-01-11 20:23:28 +01:00
|
|
|
| foo3 | - | Admin |
|
2021-01-11 17:01:01 +01:00
|
|
|
+------+-----------------+--------------------------+
|
|
|
|
|
|
|
|
OUTPUT,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
private function apiKeyWithRoles(string $key, array $roles): ApiKey
|
|
|
|
{
|
|
|
|
$apiKey = ApiKey::withKey($key);
|
|
|
|
foreach ($roles as $role) {
|
|
|
|
$apiKey->registerRole($role);
|
|
|
|
}
|
2018-11-17 17:36:22 +01:00
|
|
|
|
2021-01-11 17:01:01 +01:00
|
|
|
return $apiKey;
|
2016-08-06 18:50:50 +02:00
|
|
|
}
|
|
|
|
}
|