chore: stage all in-progress work before repo split
CI / test (push) Has been cancelled

Web app: new entities (Image, RenderedAsset, SharedImage, Token,
DeviceImageHistory), enums, repositories, controllers, message handlers,
migrations, tests, frontend upload/library/sticker UI, Vue components.

Firmware: EPD background screen binaries + gen scripts, setup_bg header.

Infra: ddev config, test bundle, gitignore coverage dir.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-05-06 12:11:31 -04:00
parent 062c52eec7
commit 12245759ac
149 changed files with 14846 additions and 92 deletions
+54
View File
@@ -0,0 +1,54 @@
<?php
declare(strict_types=1);
namespace App\Tests\Functional;
use App\Entity\User;
use Doctrine\ORM\EntityManagerInterface;
use Symfony\Bundle\FrameworkBundle\KernelBrowser;
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
abstract class AppWebTestCase extends WebTestCase
{
protected KernelBrowser $client;
private ?EntityManagerInterface $em = null;
protected function setUp(): void
{
parent::setUp();
// Create the client first — this boots the kernel and makes getContainer() available.
$this->client = static::createClient();
$this->em = null;
}
protected function em(): EntityManagerInterface
{
if ($this->em === null) {
$this->em = static::getContainer()->get(EntityManagerInterface::class);
}
return $this->em;
}
protected function createUser(string $email, string $password = 'password'): User
{
$hasher = static::getContainer()->get(UserPasswordHasherInterface::class);
$user = new User();
$user->setEmail($email);
$user->setPassword($hasher->hashPassword($user, $password));
$this->em()->persist($user);
$this->em()->flush();
return $user;
}
protected function loginAs(User $user): KernelBrowser
{
$this->client->loginUser($user);
return $this->client;
}
}