shlink/module/CLI/test/Command/Visit/DownloadGeoLiteDbCommandTest.php

101 lines
3.7 KiB
PHP
Raw Normal View History

2021-04-08 14:34:14 +03:00
<?php
declare(strict_types=1);
namespace ShlinkioTest\Shlink\CLI\Command\Visit;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Test;
use PHPUnit\Framework\MockObject\MockObject;
2021-04-08 14:34:14 +03:00
use PHPUnit\Framework\TestCase;
use Shlinkio\Shlink\CLI\Command\Visit\DownloadGeoLiteDbCommand;
use Shlinkio\Shlink\CLI\Exception\GeolocationDbUpdateFailedException;
use Shlinkio\Shlink\CLI\GeoLite\GeolocationDbUpdaterInterface;
use Shlinkio\Shlink\CLI\GeoLite\GeolocationResult;
2023-05-15 10:43:05 +03:00
use Shlinkio\Shlink\CLI\Util\ExitCode;
2021-04-08 14:34:14 +03:00
use ShlinkioTest\Shlink\CLI\CliTestUtilsTrait;
use Symfony\Component\Console\Tester\CommandTester;
use function sprintf;
class DownloadGeoLiteDbCommandTest extends TestCase
{
use CliTestUtilsTrait;
private CommandTester $commandTester;
2022-10-24 20:53:13 +03:00
private MockObject & GeolocationDbUpdaterInterface $dbUpdater;
2021-04-08 14:34:14 +03:00
protected function setUp(): void
{
$this->dbUpdater = $this->createMock(GeolocationDbUpdaterInterface::class);
$this->commandTester = $this->testerForCommand(new DownloadGeoLiteDbCommand($this->dbUpdater));
2021-04-08 14:34:14 +03:00
}
#[Test, DataProvider('provideFailureParams')]
2021-04-08 14:34:14 +03:00
public function showsProperMessageWhenGeoLiteUpdateFails(
bool $olderDbExists,
string $expectedMessage,
int $expectedExitCode,
2021-04-08 14:34:14 +03:00
): void {
$this->dbUpdater->expects($this->once())->method('checkDbUpdate')->withAnyParameters()->willReturnCallback(
function (callable $beforeDownload, callable $handleProgress) use ($olderDbExists): void {
2021-04-08 14:34:14 +03:00
$beforeDownload($olderDbExists);
$handleProgress(100, 50);
throw $olderDbExists
? GeolocationDbUpdateFailedException::withOlderDb()
: GeolocationDbUpdateFailedException::withoutOlderDb();
},
);
$this->commandTester->execute([]);
$output = $this->commandTester->getDisplay();
$exitCode = $this->commandTester->getStatusCode();
self::assertStringContainsString(
sprintf('%s GeoLite2 db file...', $olderDbExists ? 'Updating' : 'Downloading'),
$output,
);
self::assertStringContainsString($expectedMessage, $output);
self::assertSame($expectedExitCode, $exitCode);
}
2023-02-09 11:32:38 +03:00
public static function provideFailureParams(): iterable
2021-04-08 14:34:14 +03:00
{
yield 'existing db' => [
true,
'[WARNING] GeoLite2 db file update failed. Visits will continue to be located',
2023-05-15 10:43:05 +03:00
ExitCode::EXIT_WARNING,
2021-04-08 14:34:14 +03:00
];
yield 'not existing db' => [
false,
'[ERROR] GeoLite2 db file download failed. It will not be possible to locate',
2023-05-15 10:43:05 +03:00
ExitCode::EXIT_FAILURE,
2021-04-08 14:34:14 +03:00
];
}
#[Test, DataProvider('provideSuccessParams')]
2021-04-08 14:34:14 +03:00
public function printsExpectedMessageWhenNoErrorOccurs(callable $checkUpdateBehavior, string $expectedMessage): void
{
$this->dbUpdater->expects($this->once())->method('checkDbUpdate')->withAnyParameters()->willReturnCallback(
$checkUpdateBehavior,
);
2021-04-08 14:34:14 +03:00
$this->commandTester->execute([]);
$output = $this->commandTester->getDisplay();
$exitCode = $this->commandTester->getStatusCode();
self::assertStringContainsString($expectedMessage, $output);
2023-05-15 10:43:05 +03:00
self::assertSame(ExitCode::EXIT_SUCCESS, $exitCode);
2021-04-08 14:34:14 +03:00
}
2023-02-09 11:32:38 +03:00
public static function provideSuccessParams(): iterable
2021-04-08 14:34:14 +03:00
{
yield 'up to date db' => [fn () => GeolocationResult::CHECK_SKIPPED, '[INFO] GeoLite2 db file is up to date.'];
yield 'outdated db' => [function (callable $beforeDownload): GeolocationResult {
2021-04-08 14:34:14 +03:00
$beforeDownload(true);
return GeolocationResult::DB_CREATED;
2021-04-08 14:34:14 +03:00
}, '[OK] GeoLite2 db file properly downloaded.'];
}
}