Files
crm_ecosplay/tests/Entity/UserExtendedTest.php
Serreau Jovann 22f7086013 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

201 lines
5.9 KiB
PHP

<?php
namespace App\Tests\Entity;
use App\Entity\User;
use PHPUnit\Framework\TestCase;
class UserExtendedTest extends TestCase
{
private function createUser(): User
{
$user = new User();
$user->setEmail('test@test.com');
$user->setFirstName('John');
$user->setLastName('Doe');
$user->setPassword('hashed');
return $user;
}
public function testKeycloakId(): void
{
$user = $this->createUser();
$this->assertNull($user->getKeycloakId());
$user->setKeycloakId('kc-123');
$this->assertSame('kc-123', $user->getKeycloakId());
}
public function testTempPassword(): void
{
$user = $this->createUser();
$this->assertNull($user->getTempPassword());
$this->assertFalse($user->hasTempPassword());
$user->setTempPassword('temp123');
$this->assertSame('temp123', $user->getTempPassword());
$this->assertTrue($user->hasTempPassword());
$user->setTempPassword(null);
$this->assertFalse($user->hasTempPassword());
}
public function testGoogleAuthenticator(): void
{
$user = $this->createUser();
$this->assertFalse($user->isGoogleAuthenticatorEnabled());
$this->assertNull($user->getGoogleAuthenticatorSecret());
$this->assertSame('test@test.com', $user->getGoogleAuthenticatorUsername());
$user->setGoogleAuthenticatorSecret('ABCDEF');
$user->setIsGoogleAuthEnabled(true);
$this->assertTrue($user->isGoogleAuthenticatorEnabled());
$this->assertSame('ABCDEF', $user->getGoogleAuthenticatorSecret());
}
public function testEmailAuth(): void
{
$user = $this->createUser();
$this->assertFalse($user->isEmailAuthEnabled());
$this->assertSame('test@test.com', $user->getEmailAuthRecipient());
$this->assertNull($user->getEmailAuthCode());
$user->setEmailAuthCode('123456');
$this->assertSame('123456', $user->getEmailAuthCode());
}
public function testBackupCodes(): void
{
$user = $this->createUser();
$this->assertSame([], $user->getBackupCodes());
$codes = ['code1', 'code2', 'code3'];
$user->setBackupCodes($codes);
$this->assertSame($codes, $user->getBackupCodes());
$this->assertTrue($user->isBackupCode('code1'));
$this->assertFalse($user->isBackupCode('invalid'));
$user->invalidateBackupCode('code1');
$this->assertNotContains('code1', $user->getBackupCodes());
$this->assertCount(2, $user->getBackupCodes());
}
public function testAvatar(): void
{
$user = $this->createUser();
$this->assertNull($user->getAvatar());
$user->setAvatar('avatar.jpg');
$this->assertSame('avatar.jpg', $user->getAvatar());
}
public function testAvatarFile(): void
{
$user = $this->createUser();
$this->assertNull($user->getAvatarFile());
$tmpFile = tempnam(sys_get_temp_dir(), 'avatar_');
file_put_contents($tmpFile, 'fake');
$file = new \Symfony\Component\HttpFoundation\File\File($tmpFile);
$result = $user->setAvatarFile($file);
$this->assertSame($file, $user->getAvatarFile());
$this->assertSame($user, $result);
$user->setAvatarFile(null);
$this->assertNull($user->getAvatarFile());
@unlink($tmpFile);
}
public function testFullName(): void
{
$user = $this->createUser();
$this->assertSame('John Doe', $user->getFullName());
}
public function testRoles(): void
{
$user = $this->createUser();
$this->assertContains('ROLE_USER', $user->getRoles());
$user->setRoles(['ROLE_ROOT']);
$this->assertContains('ROLE_ROOT', $user->getRoles());
$this->assertContains('ROLE_USER', $user->getRoles());
}
public function testUserIdentifier(): void
{
$user = $this->createUser();
$this->assertSame('test@test.com', $user->getUserIdentifier());
}
public function testSetIsEmailAuthEnabled(): void
{
$user = $this->createUser();
$user->setIsEmailAuthEnabled(true);
$this->assertTrue($user->isEmailAuthEnabled());
$user->setKeycloakId('kc-123');
$this->assertFalse($user->isEmailAuthEnabled());
}
public function testSetIsGoogleAuthEnabled(): void
{
$user = $this->createUser();
$user->setIsGoogleAuthEnabled(true);
$this->assertFalse($user->isGoogleAuthenticatorEnabled());
$user->setGoogleAuthenticatorSecret('SECRET');
$this->assertTrue($user->isGoogleAuthenticatorEnabled());
}
public function testClearTempPassword(): void
{
$user = $this->createUser();
$user->setTempPassword('temp');
$user->clearTempPassword();
$this->assertFalse($user->hasTempPassword());
}
public function testGenerateBackupCodes(): void
{
$user = $this->createUser();
$user->generateBackupCodes(5);
$this->assertCount(5, $user->getBackupCodes());
}
public function testSerializeUnserialize(): void
{
$user = $this->createUser();
$serialized = $user->__serialize();
$this->assertArrayHasKey('id', $serialized);
$this->assertArrayHasKey('email', $serialized);
$newUser = new User();
$newUser->__unserialize($serialized);
$this->assertSame('test@test.com', $newUser->getEmail());
}
public function testCreatedAt(): void
{
$user = $this->createUser();
$this->assertInstanceOf(\DateTimeImmutable::class, $user->getCreatedAt());
}
public function testUpdatedAt(): void
{
$user = $this->createUser();
$this->assertNull($user->getUpdatedAt());
}
public function testEraseCredentials(): void
{
$user = $this->createUser();
$user->eraseCredentials();
$this->addToAssertionCount(1);
}
}