mirror of
https://github.com/shlinkio/shlink.git
synced 2025-02-17 15:59:56 +03:00
Migrated DeleteShortUrlCommandTest to use PHPUnit mocks
This commit is contained in:
parent
184ff90b9f
commit
acda7f02c6
1 changed files with 27 additions and 34 deletions
|
@ -4,9 +4,8 @@ declare(strict_types=1);
|
||||||
|
|
||||||
namespace ShlinkioTest\Shlink\CLI\Command\ShortUrl;
|
namespace ShlinkioTest\Shlink\CLI\Command\ShortUrl;
|
||||||
|
|
||||||
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
use PHPUnit\Framework\TestCase;
|
use PHPUnit\Framework\TestCase;
|
||||||
use Prophecy\Argument;
|
|
||||||
use Prophecy\Prophecy\ObjectProphecy;
|
|
||||||
use Shlinkio\Shlink\CLI\Command\ShortUrl\DeleteShortUrlCommand;
|
use Shlinkio\Shlink\CLI\Command\ShortUrl\DeleteShortUrlCommand;
|
||||||
use Shlinkio\Shlink\Core\Exception;
|
use Shlinkio\Shlink\Core\Exception;
|
||||||
use Shlinkio\Shlink\Core\ShortUrl\DeleteShortUrlServiceInterface;
|
use Shlinkio\Shlink\Core\ShortUrl\DeleteShortUrlServiceInterface;
|
||||||
|
@ -14,7 +13,6 @@ use Shlinkio\Shlink\Core\ShortUrl\Model\ShortUrlIdentifier;
|
||||||
use ShlinkioTest\Shlink\CLI\CliTestUtilsTrait;
|
use ShlinkioTest\Shlink\CLI\CliTestUtilsTrait;
|
||||||
use Symfony\Component\Console\Tester\CommandTester;
|
use Symfony\Component\Console\Tester\CommandTester;
|
||||||
|
|
||||||
use function array_pop;
|
|
||||||
use function sprintf;
|
use function sprintf;
|
||||||
|
|
||||||
use const PHP_EOL;
|
use const PHP_EOL;
|
||||||
|
@ -24,23 +22,22 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
use CliTestUtilsTrait;
|
use CliTestUtilsTrait;
|
||||||
|
|
||||||
private CommandTester $commandTester;
|
private CommandTester $commandTester;
|
||||||
private ObjectProphecy $service;
|
private MockObject $service;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
{
|
{
|
||||||
$this->service = $this->prophesize(DeleteShortUrlServiceInterface::class);
|
$this->service = $this->createMock(DeleteShortUrlServiceInterface::class);
|
||||||
$this->commandTester = $this->testerForCommand(new DeleteShortUrlCommand($this->service->reveal()));
|
$this->commandTester = $this->testerForCommand(new DeleteShortUrlCommand($this->service));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @test */
|
/** @test */
|
||||||
public function successMessageIsPrintedIfUrlIsProperlyDeleted(): void
|
public function successMessageIsPrintedIfUrlIsProperlyDeleted(): void
|
||||||
{
|
{
|
||||||
$shortCode = 'abc123';
|
$shortCode = 'abc123';
|
||||||
$deleteByShortCode = $this->service->deleteByShortCode(
|
$this->service->expects($this->once())->method('deleteByShortCode')->with(
|
||||||
ShortUrlIdentifier::fromShortCodeAndDomain($shortCode),
|
$this->equalTo(ShortUrlIdentifier::fromShortCodeAndDomain($shortCode)),
|
||||||
false,
|
$this->isFalse(),
|
||||||
)->will(function (): void {
|
);
|
||||||
});
|
|
||||||
|
|
||||||
$this->commandTester->execute(['shortCode' => $shortCode]);
|
$this->commandTester->execute(['shortCode' => $shortCode]);
|
||||||
$output = $this->commandTester->getDisplay();
|
$output = $this->commandTester->getDisplay();
|
||||||
|
@ -49,7 +46,6 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
sprintf('Short URL with short code "%s" successfully deleted.', $shortCode),
|
sprintf('Short URL with short code "%s" successfully deleted.', $shortCode),
|
||||||
$output,
|
$output,
|
||||||
);
|
);
|
||||||
$deleteByShortCode->shouldHaveBeenCalledOnce();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @test */
|
/** @test */
|
||||||
|
@ -57,15 +53,15 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
{
|
{
|
||||||
$shortCode = 'abc123';
|
$shortCode = 'abc123';
|
||||||
$identifier = ShortUrlIdentifier::fromShortCodeAndDomain($shortCode);
|
$identifier = ShortUrlIdentifier::fromShortCodeAndDomain($shortCode);
|
||||||
$deleteByShortCode = $this->service->deleteByShortCode($identifier, false)->willThrow(
|
$this->service->expects($this->once())->method('deleteByShortCode')->with(
|
||||||
Exception\ShortUrlNotFoundException::fromNotFound($identifier),
|
$this->equalTo($identifier),
|
||||||
);
|
$this->isFalse(),
|
||||||
|
)->willThrowException(Exception\ShortUrlNotFoundException::fromNotFound($identifier));
|
||||||
|
|
||||||
$this->commandTester->execute(['shortCode' => $shortCode]);
|
$this->commandTester->execute(['shortCode' => $shortCode]);
|
||||||
$output = $this->commandTester->getDisplay();
|
$output = $this->commandTester->getDisplay();
|
||||||
|
|
||||||
self::assertStringContainsString(sprintf('No URL found with short code "%s"', $shortCode), $output);
|
self::assertStringContainsString(sprintf('No URL found with short code "%s"', $shortCode), $output);
|
||||||
$deleteByShortCode->shouldHaveBeenCalledOnce();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -79,18 +75,17 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
): void {
|
): void {
|
||||||
$shortCode = 'abc123';
|
$shortCode = 'abc123';
|
||||||
$identifier = ShortUrlIdentifier::fromShortCodeAndDomain($shortCode);
|
$identifier = ShortUrlIdentifier::fromShortCodeAndDomain($shortCode);
|
||||||
$deleteByShortCode = $this->service->deleteByShortCode($identifier, Argument::type('bool'))->will(
|
$this->service->expects($this->exactly($expectedDeleteCalls))->method('deleteByShortCode')->with(
|
||||||
function (array $args) use ($shortCode): void {
|
$this->equalTo($identifier),
|
||||||
$ignoreThreshold = array_pop($args);
|
$this->isType('bool'),
|
||||||
|
)->willReturnCallback(function ($_, bool $ignoreThreshold) use ($shortCode): void {
|
||||||
if (!$ignoreThreshold) {
|
if (!$ignoreThreshold) {
|
||||||
throw Exception\DeleteShortUrlException::fromVisitsThreshold(
|
throw Exception\DeleteShortUrlException::fromVisitsThreshold(
|
||||||
10,
|
10,
|
||||||
ShortUrlIdentifier::fromShortCodeAndDomain($shortCode),
|
ShortUrlIdentifier::fromShortCodeAndDomain($shortCode),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
},
|
});
|
||||||
);
|
|
||||||
$this->commandTester->setInputs($retryAnswer);
|
$this->commandTester->setInputs($retryAnswer);
|
||||||
|
|
||||||
$this->commandTester->execute(['shortCode' => $shortCode]);
|
$this->commandTester->execute(['shortCode' => $shortCode]);
|
||||||
|
@ -101,7 +96,6 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
$shortCode,
|
$shortCode,
|
||||||
), $output);
|
), $output);
|
||||||
self::assertStringContainsString($expectedMessage, $output);
|
self::assertStringContainsString($expectedMessage, $output);
|
||||||
$deleteByShortCode->shouldHaveBeenCalledTimes($expectedDeleteCalls);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function provideRetryDeleteAnswers(): iterable
|
public function provideRetryDeleteAnswers(): iterable
|
||||||
|
@ -115,10 +109,10 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
public function deleteIsNotRetriedWhenThresholdIsReachedAndQuestionIsDeclined(): void
|
public function deleteIsNotRetriedWhenThresholdIsReachedAndQuestionIsDeclined(): void
|
||||||
{
|
{
|
||||||
$shortCode = 'abc123';
|
$shortCode = 'abc123';
|
||||||
$deleteByShortCode = $this->service->deleteByShortCode(
|
$this->service->expects($this->once())->method('deleteByShortCode')->with(
|
||||||
ShortUrlIdentifier::fromShortCodeAndDomain($shortCode),
|
$this->equalTo(ShortUrlIdentifier::fromShortCodeAndDomain($shortCode)),
|
||||||
false,
|
$this->isFalse(),
|
||||||
)->willThrow(Exception\DeleteShortUrlException::fromVisitsThreshold(
|
)->willThrowException(Exception\DeleteShortUrlException::fromVisitsThreshold(
|
||||||
10,
|
10,
|
||||||
ShortUrlIdentifier::fromShortCodeAndDomain($shortCode),
|
ShortUrlIdentifier::fromShortCodeAndDomain($shortCode),
|
||||||
));
|
));
|
||||||
|
@ -132,6 +126,5 @@ class DeleteShortUrlCommandTest extends TestCase
|
||||||
$shortCode,
|
$shortCode,
|
||||||
), $output);
|
), $output);
|
||||||
self::assertStringContainsString('Short URL was not deleted.', $output);
|
self::assertStringContainsString('Short URL was not deleted.', $output);
|
||||||
$deleteByShortCode->shouldHaveBeenCalledOnce();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue