-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
Copy pathCoursesModuleUnitTestCase.php
49 lines (41 loc) · 1.36 KB
/
CoursesModuleUnitTestCase.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<?php
declare(strict_types=1);
namespace CodelyTv\Tests\Mooc\Courses;
use CodelyTv\Mooc\Courses\Domain\Course;
use CodelyTv\Mooc\Courses\Domain\CourseRepository;
use CodelyTv\Mooc\Shared\Domain\Courses\CourseId;
use CodelyTv\Shared\Domain\DomainError;
use CodelyTv\Tests\Shared\Infrastructure\PhpUnit\UnitTestCase;
use Mockery\MockInterface;
abstract class CoursesModuleUnitTestCase extends UnitTestCase
{
private CourseRepository|MockInterface|null $repository;
protected function shouldSave(Course $course): void
{
$this->repository()
->shouldReceive('save')
->with($this->similarTo($course))
->once()
->andReturnNull();
}
protected function shouldSearch(CourseId $id, ?Course $course): void
{
$this->repository()
->shouldReceive('search')
->with($this->similarTo($id))
->once()
->andReturn($course);
}
protected function repository(): CourseRepository|MockInterface
{
return $this->repository = $this->repository ?? $this->mock(CourseRepository::class);
}
protected function searchShouldThrowException(CourseId $id, DomainError $exception)
{
$this->repository()
->shouldReceive('search')
->with($this->similarTo($id))
->once()
->andThrow($exception);
}
}