2019-11-20 22:58:16 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace ShlinkioApiTest\Shlink\Rest\Action;
|
|
|
|
|
2021-01-23 16:37:34 +03:00
|
|
|
use GuzzleHttp\Psr7\Query;
|
2020-02-02 12:46:38 +03:00
|
|
|
use Laminas\Diactoros\Uri;
|
2023-02-09 22:42:18 +03:00
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
2023-06-18 11:36:45 +03:00
|
|
|
use PHPUnit\Framework\Attributes\DataProviderExternal;
|
2023-02-09 22:42:18 +03:00
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2021-12-08 19:36:40 +03:00
|
|
|
use Shlinkio\Shlink\Common\Paginator\Paginator;
|
2019-11-20 22:58:16 +03:00
|
|
|
use Shlinkio\Shlink\TestUtils\ApiTest\ApiTestCase;
|
2023-06-18 11:36:45 +03:00
|
|
|
use ShlinkioApiTest\Shlink\Rest\Utils\ApiTestDataProviders;
|
|
|
|
use ShlinkioApiTest\Shlink\Rest\Utils\UrlBuilder;
|
2019-11-20 22:58:16 +03:00
|
|
|
|
2020-02-02 12:46:38 +03:00
|
|
|
use function sprintf;
|
|
|
|
|
2021-01-24 11:25:36 +03:00
|
|
|
class ShortUrlVisitsTest extends ApiTestCase
|
2019-11-20 22:58:16 +03:00
|
|
|
{
|
2023-06-18 11:36:45 +03:00
|
|
|
#[Test, DataProviderExternal(ApiTestDataProviders::class, 'invalidUrlsProvider')]
|
2020-02-02 15:15:08 +03:00
|
|
|
public function tryingToGetVisitsForInvalidUrlReturnsNotFoundError(
|
|
|
|
string $shortCode,
|
|
|
|
?string $domain,
|
2021-01-10 11:02:05 +03:00
|
|
|
string $expectedDetail,
|
2021-05-23 13:31:10 +03:00
|
|
|
string $apiKey,
|
2020-02-02 15:15:08 +03:00
|
|
|
): void {
|
2021-01-10 11:02:05 +03:00
|
|
|
$resp = $this->callApiWithKey(
|
|
|
|
self::METHOD_GET,
|
2023-06-18 11:36:45 +03:00
|
|
|
UrlBuilder::buildShortUrlPath($shortCode, $domain, '/visits'),
|
|
|
|
apiKey: $apiKey,
|
2021-01-10 11:02:05 +03:00
|
|
|
);
|
2019-11-27 22:48:35 +03:00
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
2019-11-20 22:58:16 +03:00
|
|
|
|
2020-10-04 01:35:14 +03:00
|
|
|
self::assertEquals(self::STATUS_NOT_FOUND, $resp->getStatusCode());
|
|
|
|
self::assertEquals(self::STATUS_NOT_FOUND, $payload['status']);
|
|
|
|
self::assertEquals('INVALID_SHORTCODE', $payload['type']);
|
|
|
|
self::assertEquals($expectedDetail, $payload['detail']);
|
|
|
|
self::assertEquals('Short URL not found', $payload['title']);
|
|
|
|
self::assertEquals($shortCode, $payload['shortCode']);
|
|
|
|
self::assertEquals($domain, $payload['domain'] ?? null);
|
2019-11-20 22:58:16 +03:00
|
|
|
}
|
2020-02-02 12:46:38 +03:00
|
|
|
|
2023-02-09 22:42:18 +03:00
|
|
|
#[Test, DataProvider('provideDomains')]
|
2020-02-02 12:46:38 +03:00
|
|
|
public function properVisitsAreReturnedWhenDomainIsProvided(?string $domain, int $expectedAmountOfVisits): void
|
|
|
|
{
|
|
|
|
$shortCode = 'ghi789';
|
|
|
|
$url = new Uri(sprintf('/short-urls/%s/visits', $shortCode));
|
|
|
|
|
|
|
|
if ($domain !== null) {
|
2021-01-23 16:37:34 +03:00
|
|
|
$url = $url->withQuery(Query::build(['domain' => $domain]));
|
2020-02-02 12:46:38 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
$resp = $this->callApiWithKey(self::METHOD_GET, (string) $url);
|
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
|
|
|
|
2021-12-08 19:36:40 +03:00
|
|
|
self::assertEquals(
|
|
|
|
$expectedAmountOfVisits,
|
|
|
|
$payload['visits']['pagination']['totalItems'] ?? Paginator::ALL_ITEMS,
|
|
|
|
);
|
2020-10-04 01:35:14 +03:00
|
|
|
self::assertCount($expectedAmountOfVisits, $payload['visits']['data'] ?? []);
|
2020-02-02 12:46:38 +03:00
|
|
|
}
|
|
|
|
|
2023-02-09 11:32:38 +03:00
|
|
|
public static function provideDomains(): iterable
|
2020-02-02 12:46:38 +03:00
|
|
|
{
|
|
|
|
yield 'domain' => ['example.com', 0];
|
|
|
|
yield 'no domain' => [null, 2];
|
|
|
|
}
|
2021-05-22 22:05:54 +03:00
|
|
|
|
2023-02-09 22:42:18 +03:00
|
|
|
#[Test, DataProvider('provideVisitsForBots')]
|
2021-05-22 22:05:54 +03:00
|
|
|
public function properVisitsAreReturnedWhenExcludingBots(bool $excludeBots, int $expectedAmountOfVisits): void
|
|
|
|
{
|
|
|
|
$shortCode = 'def456';
|
|
|
|
$url = new Uri(sprintf('/short-urls/%s/visits', $shortCode));
|
|
|
|
|
|
|
|
if ($excludeBots) {
|
|
|
|
$url = $url->withQuery(Query::build(['excludeBots' => true]));
|
|
|
|
}
|
|
|
|
|
|
|
|
$resp = $this->callApiWithKey(self::METHOD_GET, (string) $url);
|
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
|
|
|
|
2021-12-08 19:36:40 +03:00
|
|
|
self::assertEquals(
|
|
|
|
$expectedAmountOfVisits,
|
|
|
|
$payload['visits']['pagination']['totalItems'] ?? Paginator::ALL_ITEMS,
|
|
|
|
);
|
2021-05-22 22:05:54 +03:00
|
|
|
self::assertCount($expectedAmountOfVisits, $payload['visits']['data'] ?? []);
|
|
|
|
}
|
|
|
|
|
2023-02-09 11:32:38 +03:00
|
|
|
public static function provideVisitsForBots(): iterable
|
2021-05-22 22:05:54 +03:00
|
|
|
{
|
|
|
|
yield 'bots excluded' => [true, 1];
|
|
|
|
yield 'bots not excluded' => [false, 2];
|
|
|
|
}
|
2019-11-20 22:58:16 +03:00
|
|
|
}
|