mirror of
https://github.com/shlinkio/shlink.git
synced 2024-11-27 16:26:37 +03:00
Add DeleteExpiredShortUrlsCommand test
This commit is contained in:
parent
f2371e8a80
commit
527d28ad81
2 changed files with 95 additions and 0 deletions
|
@ -11,6 +11,11 @@ The format is based on [Keep a Changelog](https://keepachangelog.com), and this
|
|||
Previously, this was exposed only for orphan visits, since this can be an arbitrary value for those.
|
||||
|
||||
* [#2077](https://github.com/shlinkio/shlink/issues/2077) When sending visits to Matomo, the short URL title is now used as document title in matomo.
|
||||
* [#2059](https://github.com/shlinkio/shlink/issues/2059) Add new `short-url:delete-expired` command that can be used to programmatically delete expired short URLs.
|
||||
|
||||
Expired short URLs are those that have a `calidUntil` date in the past, or optionally, that have reached the max amount of visits.
|
||||
|
||||
This command can be run periodically by those who create many disposable URLs which are valid only for a period of time, and then can be deleted to save space.
|
||||
|
||||
### Changed
|
||||
* [#2034](https://github.com/shlinkio/shlink/issues/2034) Modernize entities, using constructor property promotion and readonly wherever possible.
|
||||
|
|
|
@ -0,0 +1,90 @@
|
|||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace ShlinkioTest\Shlink\CLI\Command\ShortUrl;
|
||||
|
||||
use PHPUnit\Framework\Attributes\Test;
|
||||
use PHPUnit\Framework\Attributes\TestWith;
|
||||
use PHPUnit\Framework\MockObject\MockObject;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Shlinkio\Shlink\CLI\Command\ShortUrl\DeleteExpiredShortUrlsCommand;
|
||||
use Shlinkio\Shlink\CLI\Util\ExitCode;
|
||||
use Shlinkio\Shlink\Core\ShortUrl\DeleteShortUrlServiceInterface;
|
||||
use Shlinkio\Shlink\Core\ShortUrl\Model\ExpiredShortUrlsConditions;
|
||||
use ShlinkioTest\Shlink\CLI\Util\CliTestUtils;
|
||||
use Symfony\Component\Console\Tester\CommandTester;
|
||||
|
||||
class DeleteExpiredShortUrlsCommandTest extends TestCase
|
||||
{
|
||||
private CommandTester $commandTester;
|
||||
private MockObject & DeleteShortUrlServiceInterface $service;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
$this->service = $this->createMock(DeleteShortUrlServiceInterface::class);
|
||||
$this->commandTester = CliTestUtils::testerForCommand(new DeleteExpiredShortUrlsCommand($this->service));
|
||||
}
|
||||
|
||||
#[Test]
|
||||
public function warningIsDisplayedAndExecutionCanBeCancelled(): void
|
||||
{
|
||||
$this->service->expects($this->never())->method('countExpiredShortUrls');
|
||||
$this->service->expects($this->never())->method('deleteExpiredShortUrls');
|
||||
|
||||
$this->commandTester->setInputs(['n']);
|
||||
$this->commandTester->execute([]);
|
||||
$output = $this->commandTester->getDisplay();
|
||||
$status = $this->commandTester->getStatusCode();
|
||||
|
||||
self::assertStringContainsString('Careful!', $output);
|
||||
self::assertEquals(ExitCode::EXIT_WARNING, $status);
|
||||
}
|
||||
|
||||
#[Test]
|
||||
#[TestWith([[], true])]
|
||||
#[TestWith([['--force' => true], false])]
|
||||
#[TestWith([['-f' => true], false])]
|
||||
public function deletionIsExecutedByDefault(array $input, bool $expectsWarning): void
|
||||
{
|
||||
$this->service->expects($this->never())->method('countExpiredShortUrls');
|
||||
$this->service->expects($this->once())->method('deleteExpiredShortUrls')->willReturn(5);
|
||||
|
||||
$this->commandTester->setInputs(['y']);
|
||||
$this->commandTester->execute($input);
|
||||
$output = $this->commandTester->getDisplay();
|
||||
$status = $this->commandTester->getStatusCode();
|
||||
|
||||
if ($expectsWarning) {
|
||||
self::assertStringContainsString('Careful!', $output);
|
||||
} else {
|
||||
self::assertStringNotContainsString('Careful!', $output);
|
||||
}
|
||||
self::assertStringContainsString('5 expired short URLs have been deleted', $output);
|
||||
self::assertEquals(ExitCode::EXIT_SUCCESS, $status);
|
||||
}
|
||||
|
||||
#[Test]
|
||||
public function countIsExecutedDuringDryRun(): void
|
||||
{
|
||||
$this->service->expects($this->once())->method('countExpiredShortUrls')->willReturn(38);
|
||||
$this->service->expects($this->never())->method('deleteExpiredShortUrls');
|
||||
|
||||
$this->commandTester->execute(['--dry-run' => true]);
|
||||
$output = $this->commandTester->getDisplay();
|
||||
$status = $this->commandTester->getStatusCode();
|
||||
|
||||
self::assertStringNotContainsString('Careful!', $output);
|
||||
self::assertStringContainsString('There are 38 expired short URLs matching provided conditions', $output);
|
||||
self::assertEquals(ExitCode::EXIT_SUCCESS, $status);
|
||||
}
|
||||
|
||||
#[Test]
|
||||
#[TestWith([[], new ExpiredShortUrlsConditions()])]
|
||||
#[TestWith([['--evaluate-max-visits' => true], new ExpiredShortUrlsConditions(maxVisitsReached: true)])]
|
||||
public function providesExpectedConditionsToService(array $extraInput, ExpiredShortUrlsConditions $conditions): void
|
||||
{
|
||||
$this->service->expects($this->once())->method('countExpiredShortUrls')->with($conditions)->willReturn(4);
|
||||
$this->commandTester->execute(['--dry-run' => true, ...$extraInput]);
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue