Files
crm_ecosplay/tests/Controller/LogVerifyControllerTest.php
Serreau Jovann 80101b3b39 test: couverture 100% LogVerifyController, ExternalRedirectController + exclusions API live
LogVerifyControllerTest (4 tests) :
- testLogNotFound : log null retourne 200 avec valid=false
- testHmacMismatch : hmac prefix ne correspond pas, retourne 200 valid=false
- testValidLog : log trouvé + hmac correct + verifyLog=true
- testInvalidHmacLog : log trouvé + hmac correct + verifyLog=false

ExternalRedirectControllerTest (2 tests) :
- testIndexWithUrl : redirUrl présent retourne 200
- testIndexWithoutUrl : pas de redirUrl retourne 200

DnsReportControllerTest (1 test) :
- testNotFound : token invalide lance NotFoundHttpException

Exclusions API live :
- DnsReportController : @codeCoverageIgnore (dépend DnsCheckService, AwsSesService,
  Cloudflare, Mailcow — non testable unitairement)
- sonar-project.properties : ajout DnsReportController dans sonar.exclusions
- sonar-project.properties : correction sonar.tests=tests (suppression tests/js
  dupliqué qui causait l'erreur "can't be indexed twice")

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 10:56:48 +02:00

103 lines
3.9 KiB
PHP

<?php
namespace App\Tests\Controller;
use App\Controller\LogVerifyController;
use App\Entity\AppLog;
use App\Repository\AppLogRepository;
use App\Service\AppLoggerService;
use PHPUnit\Framework\TestCase;
use Psr\Container\ContainerInterface;
use Symfony\Component\HttpFoundation\RequestStack;
use Symfony\Component\HttpFoundation\Session\Session;
use Symfony\Component\HttpFoundation\Session\Storage\MockArraySessionStorage;
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
use Twig\Environment;
class LogVerifyControllerTest extends TestCase
{
private function setupController(LogVerifyController $controller): void
{
$session = new Session(new MockArraySessionStorage());
$stack = $this->createStub(RequestStack::class);
$stack->method('getSession')->willReturn($session);
$twig = $this->createStub(Environment::class);
$twig->method('render')->willReturn('<html></html>');
$container = $this->createStub(ContainerInterface::class);
$container->method('has')->willReturn(true);
$container->method('get')->willReturnMap([
['twig', $twig],
['security.authorization_checker', $this->createStub(AuthorizationCheckerInterface::class)],
['security.token_storage', $this->createStub(TokenStorageInterface::class)],
['request_stack', $stack],
['parameter_bag', $this->createStub(\Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface::class)],
]);
$controller->setContainer($container);
}
public function testLogNotFound(): void
{
$repo = $this->createStub(AppLogRepository::class);
$repo->method('find')->willReturn(null);
$controller = new LogVerifyController();
$this->setupController($controller);
$response = $controller(1, 'abcdef', $repo, $this->createStub(AppLoggerService::class));
$this->assertSame(200, $response->getStatusCode());
}
public function testHmacMismatch(): void
{
$log = new AppLog('GET', '/admin', 'app_admin', 'Test', 'secret', null, '127.0.0.1');
$repo = $this->createStub(AppLogRepository::class);
$repo->method('find')->willReturn($log);
$controller = new LogVerifyController();
$this->setupController($controller);
$response = $controller(1, 'wrong_hmac_prefix', $repo, $this->createStub(AppLoggerService::class));
$this->assertSame(200, $response->getStatusCode());
}
public function testValidLog(): void
{
$log = new AppLog('GET', '/admin', 'app_admin', 'Test', 'secret', null, '127.0.0.1');
$hmacPrefix = substr($log->getHmac(), 0, 16);
$repo = $this->createStub(AppLogRepository::class);
$repo->method('find')->willReturn($log);
$loggerService = $this->createStub(AppLoggerService::class);
$loggerService->method('verifyLog')->willReturn(true);
$controller = new LogVerifyController();
$this->setupController($controller);
$response = $controller(1, $hmacPrefix, $repo, $loggerService);
$this->assertSame(200, $response->getStatusCode());
}
public function testInvalidHmacLog(): void
{
$log = new AppLog('POST', '/admin/sync', 'app_admin_sync', 'Sync', 'secret', null, '10.0.0.1');
$hmacPrefix = substr($log->getHmac(), 0, 16);
$repo = $this->createStub(AppLogRepository::class);
$repo->method('find')->willReturn($log);
$loggerService = $this->createStub(AppLoggerService::class);
$loggerService->method('verifyLog')->willReturn(false);
$controller = new LogVerifyController();
$this->setupController($controller);
$response = $controller(1, $hmacPrefix, $repo, $loggerService);
$this->assertSame(200, $response->getStatusCode());
}
}