refactor layouts module to domain/di and prepare 0.256 release
This commit is contained in:
@@ -5,18 +5,25 @@ use PHPUnit\Framework\TestCase;
|
||||
use admin\Controllers\ArticlesController;
|
||||
use Domain\Article\ArticleRepository;
|
||||
use Domain\Languages\LanguagesRepository;
|
||||
use Domain\Layouts\LayoutsRepository;
|
||||
|
||||
class ArticlesControllerTest extends TestCase
|
||||
{
|
||||
private $mockRepository;
|
||||
private $mockLanguagesRepository;
|
||||
private $mockLayoutsRepository;
|
||||
private $controller;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
$this->mockRepository = $this->createMock(ArticleRepository::class);
|
||||
$this->mockLanguagesRepository = $this->createMock(LanguagesRepository::class);
|
||||
$this->controller = new ArticlesController($this->mockRepository, $this->mockLanguagesRepository);
|
||||
$this->mockLayoutsRepository = $this->createMock(LayoutsRepository::class);
|
||||
$this->controller = new ArticlesController(
|
||||
$this->mockRepository,
|
||||
$this->mockLanguagesRepository,
|
||||
$this->mockLayoutsRepository
|
||||
);
|
||||
}
|
||||
|
||||
public function testCanCreateController(): void
|
||||
@@ -26,7 +33,11 @@ class ArticlesControllerTest extends TestCase
|
||||
|
||||
public function testConstructorAcceptsRepository(): void
|
||||
{
|
||||
$controller = new ArticlesController($this->mockRepository, $this->mockLanguagesRepository);
|
||||
$controller = new ArticlesController(
|
||||
$this->mockRepository,
|
||||
$this->mockLanguagesRepository,
|
||||
$this->mockLayoutsRepository
|
||||
);
|
||||
$this->assertInstanceOf(ArticlesController::class, $controller);
|
||||
}
|
||||
|
||||
@@ -69,8 +80,9 @@ class ArticlesControllerTest extends TestCase
|
||||
$constructor = $reflection->getConstructor();
|
||||
$params = $constructor->getParameters();
|
||||
|
||||
$this->assertCount(2, $params);
|
||||
$this->assertCount(3, $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());
|
||||
}
|
||||
}
|
||||
|
||||
56
tests/Unit/admin/Controllers/LayoutsControllerTest.php
Normal file
56
tests/Unit/admin/Controllers/LayoutsControllerTest.php
Normal file
@@ -0,0 +1,56 @@
|
||||
<?php
|
||||
namespace Tests\Unit\admin\Controllers;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use admin\Controllers\LayoutsController;
|
||||
use Domain\Layouts\LayoutsRepository;
|
||||
use Domain\Languages\LanguagesRepository;
|
||||
|
||||
class LayoutsControllerTest extends TestCase
|
||||
{
|
||||
private $mockRepository;
|
||||
private $mockLanguagesRepository;
|
||||
private $controller;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
$this->mockRepository = $this->createMock(LayoutsRepository::class);
|
||||
$this->mockLanguagesRepository = $this->createMock(LanguagesRepository::class);
|
||||
$this->controller = new LayoutsController($this->mockRepository, $this->mockLanguagesRepository);
|
||||
}
|
||||
|
||||
public function testConstructorAcceptsRepository(): void
|
||||
{
|
||||
$controller = new LayoutsController($this->mockRepository, $this->mockLanguagesRepository);
|
||||
$this->assertInstanceOf(LayoutsController::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'));
|
||||
}
|
||||
|
||||
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());
|
||||
}
|
||||
|
||||
public function testConstructorRequiresLayoutsRepository(): void
|
||||
{
|
||||
$reflection = new \ReflectionClass(LayoutsController::class);
|
||||
$constructor = $reflection->getConstructor();
|
||||
$params = $constructor->getParameters();
|
||||
|
||||
$this->assertCount(2, $params);
|
||||
$this->assertEquals('Domain\Layouts\LayoutsRepository', $params[0]->getType()->getName());
|
||||
$this->assertEquals('Domain\Languages\LanguagesRepository', $params[1]->getType()->getName());
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user