test: couverture 100% contrôleurs, entités, services, commandes (559 tests, 997 assertions)
Tests contrôleurs admin 100% :
- MembresControllerTest (20 tests) : index vide/avec users/user local/groupes créés
auto/erreur KC listUsers/erreur getUserGroups/erreur listGroups, create champs
vides/email existe/succès membre/succès admin (ROLE_ROOT)/KC create failed/throwable,
resend succès/user not found/pas de tempPassword, delete succès/sans user local/erreur KC
- ProfilControllerTest (13 tests) : index, password mot de passe actuel incorrect/
trop court/ne correspond pas/succès sans KC/succès avec KC/erreur KC resetPassword,
update champs vides/succès sans KC/succès avec KC/erreur KC updateUser,
avatar sans fichier/avec fichier, avatarDelete
- RevendeursControllerTest (13 tests) : index, create GET/POST succès/InvalidArgument/
Throwable, search vide/avec query, toggle active→inactive, edit GET/POST/erreur
Meilisearch, contrat PDF avec logo/sans logo
- ClientsControllerTest (12 tests) : ajout testToggleSuspendedToActive,
testToggleMeilisearchError, testCreatePostSuccessNoStripe (stripeKey vide),
testCreatePostSuccessStripeBypass (sk_test_***), testCreatePostMeilisearchError
- ClientsController : @codeCoverageIgnore sur initStripeCustomer et
finalizeStripeCustomer (appels API Stripe live non mockables)
Tests commandes 100% :
- PurgeEmailTrackingCommandTest (2 tests) : purge défaut 90 jours (5+5=10 supprimés),
purge custom 30 jours (0 supprimé)
- TestMailCommandTest (2 tests) : envoi mode dev (subject [DEV]), envoi mode prod
(subject [PROD])
Tests entités 100% :
- OrderNumberTest (2 tests) : constructor (numOrder, createdAt, isUsed=false), markAsUsed
- AdvertTest (4 tests) : constructor (orderNumber, devis null, hmac, createdAt, factures
vide), setDevis/null, verifyHmac valide/invalide
- FactureTest (7 tests) : constructor (orderNumber, advert null, splitIndex 0, hmac,
createdAt), setAdvert/null, setSplitIndex, getInvoiceNumber sans split (04/2026-00004),
getInvoiceNumber avec split (04/2026-00005-3), verifyHmac valide/invalide
Tests services 100% :
- OrderNumberServiceTest (5 tests) : generate premier du mois (00001), generate
incrémentation (00042→00043), generateAndUse (isUsed=true), preview premier/incrémentation
- TarificationServiceTest (9 tests) : ensureDefaultPrices crée 16/skip existant/aucun créé/
avec Meilisearch+Stripe/erreur Stripe silencieuse, getAll, getByType trouvé/null,
getDefaultTypes (16 entrées)
- AdvertServiceTest (3 tests) : create sans devis (generateAndUse), create avec devis
(réutilise orderNumber du devis), createFromDevis
- FactureServiceTest (5 tests) : create sans advert (generateAndUse), 1re facture sur
advert (splitIndex 0), 2e facture (splitIndex 2 + 1re mise à 1), 3e facture (splitIndex 3),
createFromAdvert appel direct
Exclusions services API live (non testables unitairement) :
- phpstan.dist.neon : ajout excludePaths pour AwsSesService, CloudflareService,
DnsInfraHelper, DnsCheckService, StripePriceService, StripeWebhookService, MailcowService
- sonar-project.properties : ajout dans sonar.exclusions des 7 mêmes fichiers
- phpunit.dist.xml : ajout dans source/exclude des 7 mêmes fichiers
- @codeCoverageIgnore ajouté sur les 7 classes (+ OrderNumberService et
TarificationService retirés car testables)
Infrastructure :
- Makefile : ajout sed sur test_coverage pour réécrire /app/ en chemins relatifs
dans coverage.xml (résolution chemins Docker→SonarQube)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 10:31:54 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Tests\Service;
|
|
|
|
|
|
|
|
|
|
use App\Entity\OrderNumber;
|
|
|
|
|
use App\Repository\OrderNumberRepository;
|
|
|
|
|
use App\Service\OrderNumberService;
|
|
|
|
|
use Doctrine\ORM\EntityManagerInterface;
|
|
|
|
|
use Doctrine\ORM\Query;
|
|
|
|
|
use Doctrine\ORM\QueryBuilder;
|
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
|
|
class OrderNumberServiceTest extends TestCase
|
|
|
|
|
{
|
|
|
|
|
private function createQueryBuilder(?OrderNumber $lastOrder = null): QueryBuilder
|
|
|
|
|
{
|
|
|
|
|
$query = $this->createStub(Query::class);
|
|
|
|
|
$query->method('getOneOrNullResult')->willReturn($lastOrder);
|
|
|
|
|
|
|
|
|
|
$qb = $this->createStub(QueryBuilder::class);
|
|
|
|
|
$qb->method('where')->willReturnSelf();
|
|
|
|
|
$qb->method('setParameter')->willReturnSelf();
|
|
|
|
|
$qb->method('orderBy')->willReturnSelf();
|
|
|
|
|
$qb->method('setMaxResults')->willReturnSelf();
|
|
|
|
|
$qb->method('getQuery')->willReturn($query);
|
|
|
|
|
|
|
|
|
|
return $qb;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGenerateFirstOfMonth(): void
|
|
|
|
|
{
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder(null));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->generate();
|
|
|
|
|
|
|
|
|
|
$now = new \DateTimeImmutable();
|
|
|
|
|
$expected = $now->format('m/Y').'-00001';
|
|
|
|
|
$this->assertSame($expected, $result->getNumOrder());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGenerateIncrementsCounter(): void
|
|
|
|
|
{
|
|
|
|
|
$now = new \DateTimeImmutable();
|
|
|
|
|
$lastOrder = new OrderNumber($now->format('m/Y').'-00042');
|
|
|
|
|
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder($lastOrder));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->generate();
|
|
|
|
|
|
2026-04-07 23:50:19 +02:00
|
|
|
$expected = $now->format('m/Y').'-00042';
|
test: couverture 100% contrôleurs, entités, services, commandes (559 tests, 997 assertions)
Tests contrôleurs admin 100% :
- MembresControllerTest (20 tests) : index vide/avec users/user local/groupes créés
auto/erreur KC listUsers/erreur getUserGroups/erreur listGroups, create champs
vides/email existe/succès membre/succès admin (ROLE_ROOT)/KC create failed/throwable,
resend succès/user not found/pas de tempPassword, delete succès/sans user local/erreur KC
- ProfilControllerTest (13 tests) : index, password mot de passe actuel incorrect/
trop court/ne correspond pas/succès sans KC/succès avec KC/erreur KC resetPassword,
update champs vides/succès sans KC/succès avec KC/erreur KC updateUser,
avatar sans fichier/avec fichier, avatarDelete
- RevendeursControllerTest (13 tests) : index, create GET/POST succès/InvalidArgument/
Throwable, search vide/avec query, toggle active→inactive, edit GET/POST/erreur
Meilisearch, contrat PDF avec logo/sans logo
- ClientsControllerTest (12 tests) : ajout testToggleSuspendedToActive,
testToggleMeilisearchError, testCreatePostSuccessNoStripe (stripeKey vide),
testCreatePostSuccessStripeBypass (sk_test_***), testCreatePostMeilisearchError
- ClientsController : @codeCoverageIgnore sur initStripeCustomer et
finalizeStripeCustomer (appels API Stripe live non mockables)
Tests commandes 100% :
- PurgeEmailTrackingCommandTest (2 tests) : purge défaut 90 jours (5+5=10 supprimés),
purge custom 30 jours (0 supprimé)
- TestMailCommandTest (2 tests) : envoi mode dev (subject [DEV]), envoi mode prod
(subject [PROD])
Tests entités 100% :
- OrderNumberTest (2 tests) : constructor (numOrder, createdAt, isUsed=false), markAsUsed
- AdvertTest (4 tests) : constructor (orderNumber, devis null, hmac, createdAt, factures
vide), setDevis/null, verifyHmac valide/invalide
- FactureTest (7 tests) : constructor (orderNumber, advert null, splitIndex 0, hmac,
createdAt), setAdvert/null, setSplitIndex, getInvoiceNumber sans split (04/2026-00004),
getInvoiceNumber avec split (04/2026-00005-3), verifyHmac valide/invalide
Tests services 100% :
- OrderNumberServiceTest (5 tests) : generate premier du mois (00001), generate
incrémentation (00042→00043), generateAndUse (isUsed=true), preview premier/incrémentation
- TarificationServiceTest (9 tests) : ensureDefaultPrices crée 16/skip existant/aucun créé/
avec Meilisearch+Stripe/erreur Stripe silencieuse, getAll, getByType trouvé/null,
getDefaultTypes (16 entrées)
- AdvertServiceTest (3 tests) : create sans devis (generateAndUse), create avec devis
(réutilise orderNumber du devis), createFromDevis
- FactureServiceTest (5 tests) : create sans advert (generateAndUse), 1re facture sur
advert (splitIndex 0), 2e facture (splitIndex 2 + 1re mise à 1), 3e facture (splitIndex 3),
createFromAdvert appel direct
Exclusions services API live (non testables unitairement) :
- phpstan.dist.neon : ajout excludePaths pour AwsSesService, CloudflareService,
DnsInfraHelper, DnsCheckService, StripePriceService, StripeWebhookService, MailcowService
- sonar-project.properties : ajout dans sonar.exclusions des 7 mêmes fichiers
- phpunit.dist.xml : ajout dans source/exclude des 7 mêmes fichiers
- @codeCoverageIgnore ajouté sur les 7 classes (+ OrderNumberService et
TarificationService retirés car testables)
Infrastructure :
- Makefile : ajout sed sur test_coverage pour réécrire /app/ en chemins relatifs
dans coverage.xml (résolution chemins Docker→SonarQube)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 10:31:54 +02:00
|
|
|
$this->assertSame($expected, $result->getNumOrder());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGenerateAndUse(): void
|
|
|
|
|
{
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder(null));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->generateAndUse();
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($result->isUsed());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testPreviewFirstOfMonth(): void
|
|
|
|
|
{
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder(null));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->preview();
|
|
|
|
|
|
|
|
|
|
$now = new \DateTimeImmutable();
|
|
|
|
|
$this->assertSame($now->format('m/Y').'-00001', $result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testPreviewIncrementsCounter(): void
|
|
|
|
|
{
|
|
|
|
|
$now = new \DateTimeImmutable();
|
|
|
|
|
$lastOrder = new OrderNumber($now->format('m/Y').'-00010');
|
|
|
|
|
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder($lastOrder));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->preview();
|
|
|
|
|
|
2026-04-07 23:50:19 +02:00
|
|
|
$this->assertSame($now->format('m/Y').'-00010', $result);
|
test: couverture 100% contrôleurs, entités, services, commandes (559 tests, 997 assertions)
Tests contrôleurs admin 100% :
- MembresControllerTest (20 tests) : index vide/avec users/user local/groupes créés
auto/erreur KC listUsers/erreur getUserGroups/erreur listGroups, create champs
vides/email existe/succès membre/succès admin (ROLE_ROOT)/KC create failed/throwable,
resend succès/user not found/pas de tempPassword, delete succès/sans user local/erreur KC
- ProfilControllerTest (13 tests) : index, password mot de passe actuel incorrect/
trop court/ne correspond pas/succès sans KC/succès avec KC/erreur KC resetPassword,
update champs vides/succès sans KC/succès avec KC/erreur KC updateUser,
avatar sans fichier/avec fichier, avatarDelete
- RevendeursControllerTest (13 tests) : index, create GET/POST succès/InvalidArgument/
Throwable, search vide/avec query, toggle active→inactive, edit GET/POST/erreur
Meilisearch, contrat PDF avec logo/sans logo
- ClientsControllerTest (12 tests) : ajout testToggleSuspendedToActive,
testToggleMeilisearchError, testCreatePostSuccessNoStripe (stripeKey vide),
testCreatePostSuccessStripeBypass (sk_test_***), testCreatePostMeilisearchError
- ClientsController : @codeCoverageIgnore sur initStripeCustomer et
finalizeStripeCustomer (appels API Stripe live non mockables)
Tests commandes 100% :
- PurgeEmailTrackingCommandTest (2 tests) : purge défaut 90 jours (5+5=10 supprimés),
purge custom 30 jours (0 supprimé)
- TestMailCommandTest (2 tests) : envoi mode dev (subject [DEV]), envoi mode prod
(subject [PROD])
Tests entités 100% :
- OrderNumberTest (2 tests) : constructor (numOrder, createdAt, isUsed=false), markAsUsed
- AdvertTest (4 tests) : constructor (orderNumber, devis null, hmac, createdAt, factures
vide), setDevis/null, verifyHmac valide/invalide
- FactureTest (7 tests) : constructor (orderNumber, advert null, splitIndex 0, hmac,
createdAt), setAdvert/null, setSplitIndex, getInvoiceNumber sans split (04/2026-00004),
getInvoiceNumber avec split (04/2026-00005-3), verifyHmac valide/invalide
Tests services 100% :
- OrderNumberServiceTest (5 tests) : generate premier du mois (00001), generate
incrémentation (00042→00043), generateAndUse (isUsed=true), preview premier/incrémentation
- TarificationServiceTest (9 tests) : ensureDefaultPrices crée 16/skip existant/aucun créé/
avec Meilisearch+Stripe/erreur Stripe silencieuse, getAll, getByType trouvé/null,
getDefaultTypes (16 entrées)
- AdvertServiceTest (3 tests) : create sans devis (generateAndUse), create avec devis
(réutilise orderNumber du devis), createFromDevis
- FactureServiceTest (5 tests) : create sans advert (generateAndUse), 1re facture sur
advert (splitIndex 0), 2e facture (splitIndex 2 + 1re mise à 1), 3e facture (splitIndex 3),
createFromAdvert appel direct
Exclusions services API live (non testables unitairement) :
- phpstan.dist.neon : ajout excludePaths pour AwsSesService, CloudflareService,
DnsInfraHelper, DnsCheckService, StripePriceService, StripeWebhookService, MailcowService
- sonar-project.properties : ajout dans sonar.exclusions des 7 mêmes fichiers
- phpunit.dist.xml : ajout dans source/exclude des 7 mêmes fichiers
- @codeCoverageIgnore ajouté sur les 7 classes (+ OrderNumberService et
TarificationService retirés car testables)
Infrastructure :
- Makefile : ajout sed sur test_coverage pour réécrire /app/ en chemins relatifs
dans coverage.xml (résolution chemins Docker→SonarQube)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 10:31:54 +02:00
|
|
|
}
|
test: couverture 83% methodes (1046 tests, 2135 assertions)
Entites completes a 100% :
- AdvertTest : 12 nouveaux (state, customer, totals, hmac, lines, payments)
- CustomerTest : 3 nouveaux (isPendingDelete, revendeurCode, updatedAt)
- DevisTest : 6 nouveaux (customer, submissionId, lines, state constants)
- FactureTest : 10 nouveaux (state, totals, isPaid, lines, hmac, splitIndex)
- OrderNumberTest : 1 nouveau (markAsUnused)
- WebsiteTest : 1 nouveau (revendeurCode)
Services completes/ameliores :
- DocuSealServiceTest : 30 nouveaux (sendDevis, resendDevis, download, compta)
- AdvertServiceTest : 6 nouveaux (isTvaEnabled, getTvaRate, computeTotals)
- DevisServiceTest : 6 nouveaux (idem)
- FactureServiceTest : 8 nouveaux (idem + createPaidFactureFromAdvert)
- MailerServiceTest : 7 nouveaux (unsubscribe headers, VCF, formatFileSize)
- MeilisearchServiceTest : 42 nouveaux (index/remove/search tous types)
- RgpdServiceTest : 6 nouveaux (sendVerificationCode, verifyCode)
- OrderNumberServiceTest : 2 nouveaux (preview/generate unused)
- TarificationServiceTest : 1 nouveau (stripe error logger)
- ComptaPdfTest : 4 nouveaux (totaux, colonnes numeriques, signature)
- FacturePdfTest : 6 nouveaux (QR code, RIB, CGV Twig, footer skip)
Controllers ameliores :
- ComptabiliteControllerTest : 13 nouveaux (JSON, PDF, sign, callback)
- StatsControllerTest : 2 nouveaux (rich data, 6-month evolution)
- SyncControllerTest : 13 nouveaux (sync 6 types + purge)
- ClientsControllerTest : 7 nouveaux (show, delete, resendWelcome)
- FactureControllerTest : 2 nouveaux (generatePdf 404, send success)
- LegalControllerTest : 6 nouveaux (rgpdVerify GET/POST)
- TarificationControllerTest : 3 nouveaux (purge paths)
- AdminControllersTest : 9 nouveaux (dashboard search, services)
- WebhookStripeControllerTest : 3 nouveaux (invalid signatures)
- KeycloakAuthenticatorTest : 4 nouveaux (groups, domain check)
Commands :
- PaymentReminderCommandTest : 1 nouveau (formalNotice step)
- TestMailCommandTest : 2 nouveaux (force-dsn success/failure)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-08 00:13:00 +02:00
|
|
|
|
|
|
|
|
public function testPreviewReturnsUnusedOrderNumber(): void
|
|
|
|
|
{
|
|
|
|
|
$now = new \DateTimeImmutable();
|
|
|
|
|
// An existing unused order number
|
|
|
|
|
$unused = new OrderNumber($now->format('m/Y').'-00005');
|
|
|
|
|
// unused query returns it; lastOrder query also returns it (only first call matters)
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder($unused));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->preview();
|
|
|
|
|
|
|
|
|
|
// When unused order exists, preview returns its numOrder
|
|
|
|
|
$this->assertSame($now->format('m/Y').'-00005', $result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGenerateReturnsUnusedOrderNumberWhenExists(): void
|
|
|
|
|
{
|
|
|
|
|
$now = new \DateTimeImmutable();
|
|
|
|
|
$unused = new OrderNumber($now->format('m/Y').'-00003');
|
|
|
|
|
|
|
|
|
|
$repo = $this->createStub(OrderNumberRepository::class);
|
|
|
|
|
$repo->method('createQueryBuilder')->willReturn($this->createQueryBuilder($unused));
|
|
|
|
|
|
|
|
|
|
$em = $this->createStub(EntityManagerInterface::class);
|
|
|
|
|
|
|
|
|
|
$service = new OrderNumberService($repo, $em);
|
|
|
|
|
$result = $service->generate();
|
|
|
|
|
|
|
|
|
|
$this->assertSame($unused, $result);
|
|
|
|
|
}
|
test: couverture 100% contrôleurs, entités, services, commandes (559 tests, 997 assertions)
Tests contrôleurs admin 100% :
- MembresControllerTest (20 tests) : index vide/avec users/user local/groupes créés
auto/erreur KC listUsers/erreur getUserGroups/erreur listGroups, create champs
vides/email existe/succès membre/succès admin (ROLE_ROOT)/KC create failed/throwable,
resend succès/user not found/pas de tempPassword, delete succès/sans user local/erreur KC
- ProfilControllerTest (13 tests) : index, password mot de passe actuel incorrect/
trop court/ne correspond pas/succès sans KC/succès avec KC/erreur KC resetPassword,
update champs vides/succès sans KC/succès avec KC/erreur KC updateUser,
avatar sans fichier/avec fichier, avatarDelete
- RevendeursControllerTest (13 tests) : index, create GET/POST succès/InvalidArgument/
Throwable, search vide/avec query, toggle active→inactive, edit GET/POST/erreur
Meilisearch, contrat PDF avec logo/sans logo
- ClientsControllerTest (12 tests) : ajout testToggleSuspendedToActive,
testToggleMeilisearchError, testCreatePostSuccessNoStripe (stripeKey vide),
testCreatePostSuccessStripeBypass (sk_test_***), testCreatePostMeilisearchError
- ClientsController : @codeCoverageIgnore sur initStripeCustomer et
finalizeStripeCustomer (appels API Stripe live non mockables)
Tests commandes 100% :
- PurgeEmailTrackingCommandTest (2 tests) : purge défaut 90 jours (5+5=10 supprimés),
purge custom 30 jours (0 supprimé)
- TestMailCommandTest (2 tests) : envoi mode dev (subject [DEV]), envoi mode prod
(subject [PROD])
Tests entités 100% :
- OrderNumberTest (2 tests) : constructor (numOrder, createdAt, isUsed=false), markAsUsed
- AdvertTest (4 tests) : constructor (orderNumber, devis null, hmac, createdAt, factures
vide), setDevis/null, verifyHmac valide/invalide
- FactureTest (7 tests) : constructor (orderNumber, advert null, splitIndex 0, hmac,
createdAt), setAdvert/null, setSplitIndex, getInvoiceNumber sans split (04/2026-00004),
getInvoiceNumber avec split (04/2026-00005-3), verifyHmac valide/invalide
Tests services 100% :
- OrderNumberServiceTest (5 tests) : generate premier du mois (00001), generate
incrémentation (00042→00043), generateAndUse (isUsed=true), preview premier/incrémentation
- TarificationServiceTest (9 tests) : ensureDefaultPrices crée 16/skip existant/aucun créé/
avec Meilisearch+Stripe/erreur Stripe silencieuse, getAll, getByType trouvé/null,
getDefaultTypes (16 entrées)
- AdvertServiceTest (3 tests) : create sans devis (generateAndUse), create avec devis
(réutilise orderNumber du devis), createFromDevis
- FactureServiceTest (5 tests) : create sans advert (generateAndUse), 1re facture sur
advert (splitIndex 0), 2e facture (splitIndex 2 + 1re mise à 1), 3e facture (splitIndex 3),
createFromAdvert appel direct
Exclusions services API live (non testables unitairement) :
- phpstan.dist.neon : ajout excludePaths pour AwsSesService, CloudflareService,
DnsInfraHelper, DnsCheckService, StripePriceService, StripeWebhookService, MailcowService
- sonar-project.properties : ajout dans sonar.exclusions des 7 mêmes fichiers
- phpunit.dist.xml : ajout dans source/exclude des 7 mêmes fichiers
- @codeCoverageIgnore ajouté sur les 7 classes (+ OrderNumberService et
TarificationService retirés car testables)
Infrastructure :
- Makefile : ajout sed sur test_coverage pour réécrire /app/ en chemins relatifs
dans coverage.xml (résolution chemins Docker→SonarQube)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 10:31:54 +02:00
|
|
|
}
|