add set media fields
This commit is contained in:
parent
1ce7688d33
commit
fa8efd765f
10 changed files with 61 additions and 21 deletions
|
|
@ -19,6 +19,8 @@ class FakeSetRepository implements SetRepository
|
|||
$set = new DomainSet(
|
||||
id: $id,
|
||||
name: $dto->name,
|
||||
description: $dto->description,
|
||||
iconImageUrl: $dto->iconImageUrl,
|
||||
);
|
||||
$this->setsById[$id] = $set;
|
||||
|
||||
|
|
@ -52,6 +54,8 @@ class FakeSetRepository implements SetRepository
|
|||
return new DomainSet(
|
||||
id: $set->getId(),
|
||||
name: $set->getName(),
|
||||
description: $set->getDescription(),
|
||||
iconImageUrl: $set->getIconImageUrl(),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -10,7 +10,12 @@ class ElementTest extends TestCase
|
|||
{
|
||||
public function testCreatesElementWithNullableParent(): void
|
||||
{
|
||||
$set = new DomainSet(1, 'Daily learning');
|
||||
$set = new DomainSet(
|
||||
id: 1,
|
||||
name: 'Daily learning',
|
||||
description: 'Daily learning description',
|
||||
iconImageUrl: '/assets/daily-learning-icon.svg',
|
||||
);
|
||||
$rootElement = new Element(
|
||||
id: 1,
|
||||
title: 'Root',
|
||||
|
|
|
|||
|
|
@ -7,6 +7,7 @@ use App\Element\UseCases\CreateElement\CreateElement;
|
|||
use App\Element\UseCases\CreateElement\CreateElementRequest;
|
||||
use App\Exceptions\BadRequestException;
|
||||
use App\Set\CreateSetDto;
|
||||
use App\Set\Set as DomainSet;
|
||||
use DomainException;
|
||||
use Tests\Fakes\FakeElementRepository;
|
||||
use Tests\Fakes\FakeSetRepository;
|
||||
|
|
@ -30,11 +31,18 @@ class CreateElementTest extends TestCase
|
|||
);
|
||||
}
|
||||
|
||||
private function createSet(string $name): DomainSet
|
||||
{
|
||||
return $this->setRepo->create(new CreateSetDto(
|
||||
name: $name,
|
||||
description: "$name description",
|
||||
iconImageUrl: '/assets/test-set-icon.svg',
|
||||
));
|
||||
}
|
||||
|
||||
public function testCreatesRootElement(): void
|
||||
{
|
||||
$set = $this->setRepo->create(
|
||||
new CreateSetDto('Daily learning')
|
||||
);
|
||||
$set = $this->createSet('Daily learning');
|
||||
|
||||
$element = $this->createElement->execute(new CreateElementRequest(
|
||||
setId: $set->getId(),
|
||||
|
|
@ -50,9 +58,7 @@ class CreateElementTest extends TestCase
|
|||
|
||||
public function testCreatesChildElement(): void
|
||||
{
|
||||
$set = $this->setRepo->create(
|
||||
new CreateSetDto('Daily learning')
|
||||
);
|
||||
$set = $this->createSet('Daily learning');
|
||||
$rootElement = $this->createElement->execute(
|
||||
new CreateElementRequest(
|
||||
setId: $set->getId(),
|
||||
|
|
@ -114,9 +120,7 @@ class CreateElementTest extends TestCase
|
|||
|
||||
public function testThrowsWhenParentElementDoesNotExist(): void
|
||||
{
|
||||
$set = $this->setRepo->create(
|
||||
new CreateSetDto('Daily learning')
|
||||
);
|
||||
$set = $this->createSet('Daily learning');
|
||||
|
||||
$this->expectException(DomainException::class);
|
||||
$this->expectExceptionMessage(
|
||||
|
|
@ -132,9 +136,7 @@ class CreateElementTest extends TestCase
|
|||
|
||||
public function testThrowsWhenRootElementAlreadyExists(): void
|
||||
{
|
||||
$set = $this->setRepo->create(
|
||||
new CreateSetDto('Daily learning')
|
||||
);
|
||||
$set = $this->createSet('Daily learning');
|
||||
$this->createElement->execute(new CreateElementRequest(
|
||||
setId: $set->getId(),
|
||||
title: 'Root',
|
||||
|
|
@ -155,12 +157,8 @@ class CreateElementTest extends TestCase
|
|||
|
||||
public function testThrowsWhenParentBelongsToAnotherSet(): void
|
||||
{
|
||||
$parentSet = $this->setRepo->create(
|
||||
new CreateSetDto('Parent set')
|
||||
);
|
||||
$childSet = $this->setRepo->create(
|
||||
new CreateSetDto('Child set')
|
||||
);
|
||||
$parentSet = $this->createSet('Parent set');
|
||||
$childSet = $this->createSet('Child set');
|
||||
$parentElement = $this->createElement->execute(
|
||||
new CreateElementRequest(
|
||||
setId: $parentSet->getId(),
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue