Files
crm_ecosplay/tests/MessageHandler/AppLogMessageHandlerTest.php

48 lines
1.6 KiB
PHP
Raw Normal View History

test: couverture entités, handlers, commandes (574 tests, 1028 assertions) Tests entités complémentaires : - AttestationTest : ajout setEmailTracking avec EmailTracking et null (95→98%) - CustomerTest : ajout vérification getUpdatedAt après setState - ServiceTest : ajout testSetStatusSameStatus (branche oldStatus === status, pas d'ajout dans statusHistory) - UserExtendedTest : ajout testAvatarFile avec File réel + null (97→98%) - OrderNumberTest : constructor + markAsUsed (100%) - AdvertTest : constructor, setDevis/null, verifyHmac valid/invalid (100%) - FactureTest : constructor, setAdvert/null, splitIndex, getInvoiceNumber sans/avec split, verifyHmac valid/invalid (100%) Tests MessageHandlers : - AppLogMessageHandlerTest (2 tests) : __invoke avec userId (find user + persist AppLog + flush), __invoke sans userId (userId null, user null) - MeilisearchSyncMessageHandlerTest (12 tests) : remove customer/revendeur/price/ unknown, index customer trouvé/non trouvé, index revendeur trouvé/non trouvé, index price trouvé/non trouvé, index unknown type Tests services : - OrderNumberServiceTest (5 tests) : generate/preview premier et incrémenté, generateAndUse - TarificationServiceTest (9 tests) : ensureDefaultPrices tous/skip/aucun/ avec Meilisearch+Stripe/erreur Stripe, getAll, getByType, getDefaultTypes - AdvertServiceTest (3 tests) : create sans/avec devis, createFromDevis - FactureServiceTest (5 tests) : create sans advert, 1re/2e/3e facture, direct Exclusions services API live : - phpunit.dist.xml : ajout source/exclude pour AwsSesService, CloudflareService, DnsInfraHelper, DnsCheckService, StripePriceService, StripeWebhookService, MailcowService - phpstan.dist.neon : ajout excludePaths pour les 7 services - sonar-project.properties : ajout sonar.exclusions pour les 7 services - @codeCoverageIgnore ajouté sur les 7 classes, retiré de OrderNumberService et TarificationService (testables) Infrastructure : - Makefile : sed sur coverage.xml pour réécrire /app/ en chemins relatifs Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 10:37:37 +02:00
<?php
namespace App\Tests\MessageHandler;
use App\Entity\AppLog;
use App\Entity\User;
use App\Message\AppLogMessage;
use App\MessageHandler\AppLogMessageHandler;
use App\Repository\UserRepository;
use Doctrine\ORM\EntityManagerInterface;
use PHPUnit\Framework\TestCase;
class AppLogMessageHandlerTest extends TestCase
{
public function testInvokeWithUser(): void
{
$user = new User();
$user->setEmail('t@t.com');
$user->setFirstName('T');
$user->setLastName('T');
$user->setPassword('h');
$userRepo = $this->createStub(UserRepository::class);
$userRepo->method('find')->willReturn($user);
$em = $this->createMock(EntityManagerInterface::class);
$em->expects($this->once())->method('persist')->with($this->isInstanceOf(AppLog::class));
$em->expects($this->once())->method('flush');
$handler = new AppLogMessageHandler($em, $userRepo, 'test-secret');
$message = new AppLogMessage('GET', '/admin', 'app_admin_index', 'Consultation', 1, '127.0.0.1');
$handler($message);
}
public function testInvokeWithoutUser(): void
{
$userRepo = $this->createStub(UserRepository::class);
$em = $this->createMock(EntityManagerInterface::class);
$em->expects($this->once())->method('persist')->with($this->isInstanceOf(AppLog::class));
$em->expects($this->once())->method('flush');
$handler = new AppLogMessageHandler($em, $userRepo, 'test-secret');
$message = new AppLogMessage('POST', '/admin/sync', 'app_admin_sync_all', 'Synchronisation', null, '10.0.0.1');
$handler($message);
}
}