Files
crm_ecosplay/tests/Controller/ExternalRedirectControllerTest.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

59 lines
2.2 KiB
PHP

<?php
namespace App\Tests\Controller;
use App\Controller\ExternalRedirectController;
use PHPUnit\Framework\TestCase;
use Psr\Container\ContainerInterface;
use Symfony\Component\HttpFoundation\Request;
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 ExternalRedirectControllerTest extends TestCase
{
private function setupController(ExternalRedirectController $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 testIndexWithUrl(): void
{
$controller = new ExternalRedirectController();
$this->setupController($controller);
$request = new Request(['redirUrl' => 'https://example.com']);
$response = $controller->index($request);
$this->assertSame(200, $response->getStatusCode());
}
public function testIndexWithoutUrl(): void
{
$controller = new ExternalRedirectController();
$this->setupController($controller);
$request = new Request();
$response = $controller->index($request);
$this->assertSame(200, $response->getStatusCode());
}
}