2019-11-20 20:58:16 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace ShlinkioApiTest\Shlink\Rest\Action;
|
|
|
|
|
2021-01-23 14:37:34 +01:00
|
|
|
use GuzzleHttp\Psr7\Query;
|
2020-02-02 10:46:38 +01:00
|
|
|
use Laminas\Diactoros\Uri;
|
2021-12-08 17:36:40 +01:00
|
|
|
use Shlinkio\Shlink\Common\Paginator\Paginator;
|
2019-11-20 20:58:16 +01:00
|
|
|
use Shlinkio\Shlink\TestUtils\ApiTest\ApiTestCase;
|
2020-02-02 13:15:08 +01:00
|
|
|
use ShlinkioApiTest\Shlink\Rest\Utils\NotFoundUrlHelpersTrait;
|
2019-11-20 20:58:16 +01:00
|
|
|
|
2020-02-02 10:46:38 +01:00
|
|
|
use function sprintf;
|
|
|
|
|
2021-01-24 09:25:36 +01:00
|
|
|
class ShortUrlVisitsTest extends ApiTestCase
|
2019-11-20 20:58:16 +01:00
|
|
|
{
|
2020-02-02 13:15:08 +01:00
|
|
|
use NotFoundUrlHelpersTrait;
|
2019-11-27 20:48:35 +01:00
|
|
|
|
2020-02-02 13:15:08 +01:00
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideInvalidUrls
|
|
|
|
*/
|
|
|
|
public function tryingToGetVisitsForInvalidUrlReturnsNotFoundError(
|
|
|
|
string $shortCode,
|
|
|
|
?string $domain,
|
2021-01-10 09:02:05 +01:00
|
|
|
string $expectedDetail,
|
2021-05-23 12:31:10 +02:00
|
|
|
string $apiKey,
|
2020-02-02 13:15:08 +01:00
|
|
|
): void {
|
2021-01-10 09:02:05 +01:00
|
|
|
$resp = $this->callApiWithKey(
|
|
|
|
self::METHOD_GET,
|
|
|
|
$this->buildShortUrlPath($shortCode, $domain, '/visits'),
|
|
|
|
[],
|
|
|
|
$apiKey,
|
|
|
|
);
|
2019-11-27 20:48:35 +01:00
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
2019-11-20 20:58:16 +01:00
|
|
|
|
2020-10-04 00:35:14 +02: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 20:58:16 +01:00
|
|
|
}
|
2020-02-02 10:46:38 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideDomains
|
|
|
|
*/
|
|
|
|
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 14:37:34 +01:00
|
|
|
$url = $url->withQuery(Query::build(['domain' => $domain]));
|
2020-02-02 10:46:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$resp = $this->callApiWithKey(self::METHOD_GET, (string) $url);
|
|
|
|
$payload = $this->getJsonResponsePayload($resp);
|
|
|
|
|
2021-12-08 17:36:40 +01:00
|
|
|
self::assertEquals(
|
|
|
|
$expectedAmountOfVisits,
|
|
|
|
$payload['visits']['pagination']['totalItems'] ?? Paginator::ALL_ITEMS,
|
|
|
|
);
|
2020-10-04 00:35:14 +02:00
|
|
|
self::assertCount($expectedAmountOfVisits, $payload['visits']['data'] ?? []);
|
2020-02-02 10:46:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function provideDomains(): iterable
|
|
|
|
{
|
|
|
|
yield 'domain' => ['example.com', 0];
|
|
|
|
yield 'no domain' => [null, 2];
|
|
|
|
}
|
2021-05-22 21:05:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @dataProvider provideVisitsForBots
|
|
|
|
*/
|
|
|
|
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 17:36:40 +01:00
|
|
|
self::assertEquals(
|
|
|
|
$expectedAmountOfVisits,
|
|
|
|
$payload['visits']['pagination']['totalItems'] ?? Paginator::ALL_ITEMS,
|
|
|
|
);
|
2021-05-22 21:05:54 +02:00
|
|
|
self::assertCount($expectedAmountOfVisits, $payload['visits']['data'] ?? []);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function provideVisitsForBots(): iterable
|
|
|
|
{
|
|
|
|
yield 'bots excluded' => [true, 1];
|
|
|
|
yield 'bots not excluded' => [false, 2];
|
|
|
|
}
|
2019-11-20 20:58:16 +01:00
|
|
|
}
|