2022-04-23 04:17:32 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace ShlinkioApiTest\Shlink\Rest\Action;
|
|
|
|
|
|
|
|
use GuzzleHttp\RequestOptions;
|
2023-02-09 13:42:18 -06:00
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2022-04-23 04:17:32 -05:00
|
|
|
use Shlinkio\Shlink\TestUtils\ApiTest\ApiTestCase;
|
|
|
|
|
|
|
|
use function sprintf;
|
|
|
|
|
|
|
|
class DomainVisitsTest extends ApiTestCase
|
|
|
|
{
|
2023-02-09 13:42:18 -06:00
|
|
|
#[Test, DataProvider('provideDomains')]
|
2022-04-23 04:17:32 -05:00
|
|
|
public function expectedVisitsAreReturned(
|
|
|
|
string $apiKey,
|
|
|
|
string $domain,
|
|
|
|
bool $excludeBots,
|
|
|
|
int $expectedVisitsAmount,
|
|
|
|
): void {
|
|
|
|
$resp = $this->callApiWithKey(self::METHOD_GET, sprintf('/domains/%s/visits', $domain), [
|
|
|
|
RequestOptions::QUERY => $excludeBots ? ['excludeBots' => true] : [],
|
|
|
|
], $apiKey);
|
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
|
|
|
|
|
|
|
self::assertEquals(self::STATUS_OK, $resp->getStatusCode());
|
|
|
|
self::assertArrayHasKey('visits', $payload);
|
|
|
|
self::assertArrayHasKey('data', $payload['visits']);
|
|
|
|
self::assertCount($expectedVisitsAmount, $payload['visits']['data']);
|
|
|
|
}
|
|
|
|
|
2023-02-09 02:32:38 -06:00
|
|
|
public static function provideDomains(): iterable
|
2022-04-23 04:17:32 -05:00
|
|
|
{
|
|
|
|
yield 'example.com with admin API key' => ['valid_api_key', 'example.com', false, 0];
|
|
|
|
yield 'DEFAULT with admin API key' => ['valid_api_key', 'DEFAULT', false, 7];
|
|
|
|
yield 'DEFAULT with admin API key and no bots' => ['valid_api_key', 'DEFAULT', true, 6];
|
|
|
|
yield 'DEFAULT with domain API key' => ['domain_api_key', 'DEFAULT', false, 0];
|
|
|
|
yield 'DEFAULT with author API key' => ['author_api_key', 'DEFAULT', false, 5];
|
|
|
|
yield 'DEFAULT with author API key and no bots' => ['author_api_key', 'DEFAULT', true, 4];
|
|
|
|
}
|
|
|
|
|
2023-02-09 13:42:18 -06:00
|
|
|
#[Test, DataProvider('provideApiKeysAndTags')]
|
2022-04-23 04:17:32 -05:00
|
|
|
public function notFoundErrorIsReturnedForInvalidTags(string $apiKey, string $domain): void
|
|
|
|
{
|
|
|
|
$resp = $this->callApiWithKey(self::METHOD_GET, sprintf('/domains/%s/visits', $domain), [], $apiKey);
|
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
|
|
|
|
|
|
|
self::assertEquals(self::STATUS_NOT_FOUND, $resp->getStatusCode());
|
|
|
|
self::assertEquals(self::STATUS_NOT_FOUND, $payload['status']);
|
2024-02-12 13:29:40 -06:00
|
|
|
self::assertEquals('https://shlink.io/api/error/domain-not-found', $payload['type']);
|
2022-04-23 04:17:32 -05:00
|
|
|
self::assertEquals(sprintf('Domain with authority "%s" could not be found', $domain), $payload['detail']);
|
|
|
|
self::assertEquals('Domain not found', $payload['title']);
|
|
|
|
self::assertEquals($domain, $payload['authority']);
|
|
|
|
}
|
|
|
|
|
2023-02-09 02:32:38 -06:00
|
|
|
public static function provideApiKeysAndTags(): iterable
|
2022-04-23 04:17:32 -05:00
|
|
|
{
|
|
|
|
yield 'admin API key with invalid domain' => ['valid_api_key', 'invalid_domain.com'];
|
|
|
|
yield 'domain API key with not-owned valid domain' => ['domain_api_key', 'this_domain_is_detached.com'];
|
|
|
|
yield 'author API key with valid domain not used in URLs' => ['author_api_key', 'this_domain_is_detached.com'];
|
|
|
|
}
|
2022-08-13 10:48:55 -05:00
|
|
|
|
2023-02-09 13:42:18 -06:00
|
|
|
#[Test, DataProvider('provideApiVersions')]
|
2022-08-13 10:48:55 -05:00
|
|
|
public function expectedNotFoundTypeIsReturnedForApiVersion(string $version, string $expectedType): void
|
|
|
|
{
|
|
|
|
$resp = $this->callApiWithKey(self::METHOD_GET, sprintf('/rest/v%s/domains/invalid.com/visits', $version));
|
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
|
|
|
|
|
|
|
self::assertEquals($expectedType, $payload['type']);
|
|
|
|
}
|
|
|
|
|
2023-02-09 02:32:38 -06:00
|
|
|
public static function provideApiVersions(): iterable
|
2022-08-13 10:48:55 -05:00
|
|
|
{
|
2024-02-12 13:29:40 -06:00
|
|
|
yield ['1', 'https://shlink.io/api/error/domain-not-found'];
|
|
|
|
yield ['2', 'https://shlink.io/api/error/domain-not-found'];
|
2022-08-13 10:48:55 -05:00
|
|
|
yield ['3', 'https://shlink.io/api/error/domain-not-found'];
|
|
|
|
}
|
2022-04-23 04:17:32 -05:00
|
|
|
}
|