ver 0.262 - pages module refactor and admin UX fixes

This commit is contained in:
2026-02-13 21:17:21 +01:00
parent a1633491d5
commit b4559a5e74
44 changed files with 2235 additions and 1803 deletions

View File

@@ -6,12 +6,14 @@ use admin\Controllers\ArticlesController;
use Domain\Article\ArticleRepository;
use Domain\Languages\LanguagesRepository;
use Domain\Layouts\LayoutsRepository;
use Domain\Pages\PagesRepository;
class ArticlesControllerTest extends TestCase
{
private $mockRepository;
private $mockLanguagesRepository;
private $mockLayoutsRepository;
private $mockPagesRepository;
private $controller;
protected function setUp(): void
@@ -19,10 +21,12 @@ class ArticlesControllerTest extends TestCase
$this->mockRepository = $this->createMock(ArticleRepository::class);
$this->mockLanguagesRepository = $this->createMock(LanguagesRepository::class);
$this->mockLayoutsRepository = $this->createMock(LayoutsRepository::class);
$this->mockPagesRepository = $this->createMock(PagesRepository::class);
$this->controller = new ArticlesController(
$this->mockRepository,
$this->mockLanguagesRepository,
$this->mockLayoutsRepository
$this->mockLayoutsRepository,
$this->mockPagesRepository
);
}
@@ -36,7 +40,8 @@ class ArticlesControllerTest extends TestCase
$controller = new ArticlesController(
$this->mockRepository,
$this->mockLanguagesRepository,
$this->mockLayoutsRepository
$this->mockLayoutsRepository,
$this->mockPagesRepository
);
$this->assertInstanceOf(ArticlesController::class, $controller);
}
@@ -124,9 +129,10 @@ class ArticlesControllerTest extends TestCase
$constructor = $reflection->getConstructor();
$params = $constructor->getParameters();
$this->assertCount(3, $params);
$this->assertCount(4, $params);
$this->assertEquals('Domain\Article\ArticleRepository', $params[0]->getType()->getName());
$this->assertEquals('Domain\Languages\LanguagesRepository', $params[1]->getType()->getName());
$this->assertEquals('Domain\Layouts\LayoutsRepository', $params[2]->getType()->getName());
$this->assertEquals('Domain\Pages\PagesRepository', $params[3]->getType()->getName());
}
}

View File

@@ -0,0 +1,82 @@
<?php
namespace Tests\Unit\admin\Controllers;
use admin\Controllers\PagesController;
use Domain\Languages\LanguagesRepository;
use Domain\Layouts\LayoutsRepository;
use Domain\Pages\PagesRepository;
use PHPUnit\Framework\TestCase;
class PagesControllerTest extends TestCase
{
private $mockRepository;
private $mockLanguagesRepository;
private $mockLayoutsRepository;
private $controller;
protected function setUp(): void
{
$this->mockRepository = $this->createMock(PagesRepository::class);
$this->mockLanguagesRepository = $this->createMock(LanguagesRepository::class);
$this->mockLayoutsRepository = $this->createMock(LayoutsRepository::class);
$this->controller = new PagesController(
$this->mockRepository,
$this->mockLanguagesRepository,
$this->mockLayoutsRepository
);
}
public function testConstructorAcceptsRepositories(): void
{
$controller = new PagesController(
$this->mockRepository,
$this->mockLanguagesRepository,
$this->mockLayoutsRepository
);
$this->assertInstanceOf(PagesController::class, $controller);
}
public function testHasMainActionMethods(): void
{
$this->assertTrue(method_exists($this->controller, 'list'));
$this->assertTrue(method_exists($this->controller, 'edit'));
$this->assertTrue(method_exists($this->controller, 'save'));
$this->assertTrue(method_exists($this->controller, 'delete'));
$this->assertTrue(method_exists($this->controller, 'menuEdit'));
$this->assertTrue(method_exists($this->controller, 'menuSave'));
$this->assertTrue(method_exists($this->controller, 'menuDelete'));
$this->assertTrue(method_exists($this->controller, 'savePagesOrder'));
$this->assertTrue(method_exists($this->controller, 'saveArticlesOrder'));
$this->assertTrue(method_exists($this->controller, 'generateSeoLink'));
}
public function testActionMethodReturnTypes(): void
{
$reflection = new \ReflectionClass($this->controller);
$this->assertEquals('string', (string)$reflection->getMethod('list')->getReturnType());
$this->assertEquals('string', (string)$reflection->getMethod('edit')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('save')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('delete')->getReturnType());
$this->assertEquals('string', (string)$reflection->getMethod('menuEdit')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('menuSave')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('menuDelete')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('savePagesOrder')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('saveArticlesOrder')->getReturnType());
$this->assertEquals('void', (string)$reflection->getMethod('generateSeoLink')->getReturnType());
}
public function testConstructorRequiresPagesLanguagesAndLayoutsRepositories(): void
{
$reflection = new \ReflectionClass(PagesController::class);
$constructor = $reflection->getConstructor();
$params = $constructor->getParameters();
$this->assertCount(3, $params);
$this->assertEquals('Domain\Pages\PagesRepository', $params[0]->getType()->getName());
$this->assertEquals('Domain\Languages\LanguagesRepository', $params[1]->getType()->getName());
$this->assertEquals('Domain\Layouts\LayoutsRepository', $params[2]->getType()->getName());
}
}