mirror of
https://github.com/shlinkio/shlink.git
synced 2025-01-07 06:34:05 -06:00
99 lines
3.4 KiB
PHP
99 lines
3.4 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
|
|
namespace ShlinkioTest\Shlink\Rest\Action\ShortUrl;
|
|
|
|
use PHPUnit\Framework\Assert;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Prophecy\Argument;
|
|
use Prophecy\Prophecy\ObjectProphecy;
|
|
use Psr\Http\Message\UriInterface;
|
|
use Shlinkio\Shlink\Core\Entity\ShortUrl;
|
|
use Shlinkio\Shlink\Core\Model\ShortUrlMeta;
|
|
use Shlinkio\Shlink\Core\Service\UrlShortenerInterface;
|
|
use Shlinkio\Shlink\Rest\Action\ShortUrl\SingleStepCreateShortUrlAction;
|
|
use Shlinkio\Shlink\Rest\Service\ApiKeyServiceInterface;
|
|
use Zend\Diactoros\Response\JsonResponse;
|
|
use Zend\Diactoros\ServerRequest;
|
|
|
|
class SingleStepCreateShortUrlActionTest extends TestCase
|
|
{
|
|
/** @var SingleStepCreateShortUrlAction */
|
|
private $action;
|
|
/** @var ObjectProphecy */
|
|
private $urlShortener;
|
|
/** @var ObjectProphecy */
|
|
private $apiKeyService;
|
|
|
|
public function setUp(): void
|
|
{
|
|
$this->urlShortener = $this->prophesize(UrlShortenerInterface::class);
|
|
$this->apiKeyService = $this->prophesize(ApiKeyServiceInterface::class);
|
|
|
|
$this->action = new SingleStepCreateShortUrlAction(
|
|
$this->urlShortener->reveal(),
|
|
$this->apiKeyService->reveal(),
|
|
[
|
|
'schema' => 'http',
|
|
'hostname' => 'foo.com',
|
|
]
|
|
);
|
|
}
|
|
|
|
/** @test */
|
|
public function errorResponseIsReturnedIfInvalidApiKeyIsProvided()
|
|
{
|
|
$request = (new ServerRequest())->withQueryParams(['apiKey' => 'abc123']);
|
|
$findApiKey = $this->apiKeyService->check('abc123')->willReturn(false);
|
|
|
|
/** @var JsonResponse $resp */
|
|
$resp = $this->action->handle($request);
|
|
$payload = $resp->getPayload();
|
|
|
|
$this->assertEquals(400, $resp->getStatusCode());
|
|
$this->assertEquals('INVALID_ARGUMENT', $payload['error']);
|
|
$this->assertEquals('No API key was provided or it is not valid', $payload['message']);
|
|
$findApiKey->shouldHaveBeenCalled();
|
|
}
|
|
|
|
/** @test */
|
|
public function errorResponseIsReturnedIfNoUrlIsProvided()
|
|
{
|
|
$request = (new ServerRequest())->withQueryParams(['apiKey' => 'abc123']);
|
|
$findApiKey = $this->apiKeyService->check('abc123')->willReturn(true);
|
|
|
|
/** @var JsonResponse $resp */
|
|
$resp = $this->action->handle($request);
|
|
$payload = $resp->getPayload();
|
|
|
|
$this->assertEquals(400, $resp->getStatusCode());
|
|
$this->assertEquals('INVALID_ARGUMENT', $payload['error']);
|
|
$this->assertEquals('A URL was not provided', $payload['message']);
|
|
$findApiKey->shouldHaveBeenCalled();
|
|
}
|
|
|
|
/** @test */
|
|
public function properDataIsPassedWhenGeneratingShortCode()
|
|
{
|
|
$request = (new ServerRequest())->withQueryParams([
|
|
'apiKey' => 'abc123',
|
|
'longUrl' => 'http://foobar.com',
|
|
]);
|
|
$findApiKey = $this->apiKeyService->check('abc123')->willReturn(true);
|
|
$generateShortCode = $this->urlShortener->urlToShortCode(
|
|
Argument::that(function (UriInterface $argument) {
|
|
Assert::assertEquals('http://foobar.com', (string) $argument);
|
|
return $argument;
|
|
}),
|
|
[],
|
|
ShortUrlMeta::createEmpty()
|
|
)->willReturn(new ShortUrl(''));
|
|
|
|
$resp = $this->action->handle($request);
|
|
|
|
$this->assertEquals(200, $resp->getStatusCode());
|
|
$findApiKey->shouldHaveBeenCalled();
|
|
$generateShortCode->shouldHaveBeenCalled();
|
|
}
|
|
}
|