Working state
This commit is contained in:
@@ -7,69 +7,70 @@ use App\Shared\Database\Provisioner;
|
||||
use PDO;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
#[\PHPUnit\Framework\Attributes\AllowMockObjectsWithoutExpectations]
|
||||
|
||||
final class ProvisionerTest extends TestCase
|
||||
{
|
||||
private PDO $db;
|
||||
private string $lockPath;
|
||||
private bool $lockExistedBefore;
|
||||
|
||||
/** @var array<string, string> */
|
||||
private array $envBackup;
|
||||
private array $envBackup = [];
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
$this->db = new PDO('sqlite::memory:', options: [
|
||||
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
|
||||
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
|
||||
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
|
||||
]);
|
||||
$this->db->sqliteCreateFunction('strip_tags', 'strip_tags', 1);
|
||||
|
||||
$this->lockPath = dirname(__DIR__, 2) . '/database/.provision.lock';
|
||||
$this->lockExistedBefore = file_exists($this->lockPath);
|
||||
@unlink($this->lockPath);
|
||||
|
||||
$this->envBackup = [
|
||||
'ADMIN_USERNAME' => $_ENV['ADMIN_USERNAME'] ?? '',
|
||||
'ADMIN_EMAIL' => $_ENV['ADMIN_EMAIL'] ?? '',
|
||||
'ADMIN_PASSWORD' => $_ENV['ADMIN_PASSWORD'] ?? '',
|
||||
'ADMIN_USERNAME' => $_ENV['ADMIN_USERNAME'] ?? null,
|
||||
'ADMIN_EMAIL' => $_ENV['ADMIN_EMAIL'] ?? null,
|
||||
'ADMIN_PASSWORD' => $_ENV['ADMIN_PASSWORD'] ?? null,
|
||||
];
|
||||
|
||||
$_ENV['ADMIN_USERNAME'] = 'shared-admin';
|
||||
$_ENV['ADMIN_EMAIL'] = 'shared-admin@example.com';
|
||||
$_ENV['ADMIN_PASSWORD'] = 'strong-secret';
|
||||
$_ENV['ADMIN_USERNAME'] = 'Admin';
|
||||
$_ENV['ADMIN_EMAIL'] = 'Admin@example.com';
|
||||
$_ENV['ADMIN_PASSWORD'] = 'secret1234';
|
||||
}
|
||||
|
||||
protected function tearDown(): void
|
||||
{
|
||||
foreach ($this->envBackup as $key => $value) {
|
||||
$_ENV[$key] = $value;
|
||||
}
|
||||
@unlink($this->lockPath);
|
||||
|
||||
if (!$this->lockExistedBefore && file_exists($this->lockPath)) {
|
||||
@unlink($this->lockPath);
|
||||
foreach ($this->envBackup as $key => $value) {
|
||||
if ($value === null) {
|
||||
unset($_ENV[$key]);
|
||||
} else {
|
||||
$_ENV[$key] = $value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function testRunAppliesMigrationsSeedsAdminAndCreatesLockFile(): void
|
||||
public function testRunCreatesProvisionLockAndSeedsAdminUser(): void
|
||||
{
|
||||
Provisioner::run($this->db);
|
||||
|
||||
self::assertFileExists($this->lockPath);
|
||||
|
||||
$migrationCount = (int) $this->db->query('SELECT COUNT(*) FROM migrations')->fetchColumn();
|
||||
self::assertGreaterThan(0, $migrationCount, 'Les migrations doivent être enregistrées');
|
||||
$row = $this->db->query('SELECT username, email, role FROM users')->fetch();
|
||||
|
||||
$admin = $this->db->query("SELECT username, email, role FROM users WHERE username = 'shared-admin'")->fetch();
|
||||
self::assertIsArray($admin);
|
||||
self::assertSame('shared-admin@example.com', $admin['email']);
|
||||
self::assertSame('admin', $admin['role']);
|
||||
self::assertIsArray($row);
|
||||
self::assertSame('admin', $row['username']);
|
||||
self::assertSame('admin@example.com', $row['email']);
|
||||
self::assertSame('admin', $row['role']);
|
||||
}
|
||||
|
||||
public function testRunIsIdempotentForAdminSeed(): void
|
||||
public function testRunIsIdempotent(): void
|
||||
{
|
||||
Provisioner::run($this->db);
|
||||
Provisioner::run($this->db);
|
||||
|
||||
$adminCount = (int) $this->db->query("SELECT COUNT(*) FROM users WHERE username = 'shared-admin'")->fetchColumn();
|
||||
self::assertSame(1, $adminCount);
|
||||
$count = (int) $this->db->query('SELECT COUNT(*) FROM users WHERE username = "admin"')->fetchColumn();
|
||||
|
||||
self::assertSame(1, $count);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user