GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Test Failed
Push — master ( 99496c...f0f55b )
by Giacomo
12:21 queued 12s
created

onFlushWillAggregateAllTheEventAwareEntities()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 39
Code Lines 26

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 26
c 1
b 0
f 0
dl 0
loc 39
rs 9.504
cc 1
nc 1
nop 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Dsantang\DomainEventsDoctrine\Tests\Unit\EventsRecorder;
6
7
use Doctrine\ORM\EntityManagerInterface;
8
use Doctrine\ORM\Event\OnFlushEventArgs;
9
use Doctrine\ORM\UnitOfWork;
10
use Dsantang\DomainEvents\Counter;
11
use Dsantang\DomainEvents\DomainEvent;
12
use Dsantang\DomainEvents\EventAware;
13
use Dsantang\DomainEvents\Registry\EventsRegistry;
14
use Dsantang\DomainEventsDoctrine\Aggregator;
15
use Dsantang\DomainEventsDoctrine\EventsRecorder\OrderedDoctrineEventsRecorder;
16
use Dsantang\DomainEventsDoctrine\Tests\RandomDomainEvent;
17
use phpDocumentor\Reflection\Types\Object_;
18
use PHPUnit\Framework\TestCase;
19
20
final class OrderedDoctrineEventsRecorderTest extends TestCase
21
{
22
    /**
23
     * @param DomainEvent[] $domainEvents
24
     *
25
     * @dataProvider provideEventAwareChangedEntities
26
     *
27
     * @test
28
     */
29
    public function onFlushWillAggregateAllTheEventAwareEntities(object $eventAwareEntity, array $domainEvents): void
30
    {
31
        $unitOfWork = $this->createMock(UnitOfWork::class);
32
33
        $unitOfWork->expects(self::once())
34
                   ->method('getScheduledEntityDeletions')
35
                   ->willReturn([new Object_()]);
36
37
        $unitOfWork->expects(self::once())
38
                   ->method('getScheduledEntityInsertions')
39
                   ->willReturn([$eventAwareEntity]);
40
41
        $unitOfWork->expects(self::once())
42
                   ->method('getScheduledEntityUpdates')
43
                   ->willReturn([$eventAwareEntity]);
44
45
        $entityManager = $this->createMock(EntityManagerInterface::class);
46
        $entityManager->expects(self::once())
47
                      ->method('getUnitOfWork')
48
                      ->willReturn($unitOfWork);
49
50
        $aggregator = $this->createMock(Aggregator::class);
51
52
        $aggregator->expects(self::once())
53
                   ->method('aggregate')
54
                   ->with(...$domainEvents);
55
56
        $eventRecorder = new OrderedDoctrineEventsRecorder($aggregator);
57
58
        $eventArgs = $this->createMock(OnFlushEventArgs::class);
59
        $eventArgs->expects(self::once())
60
                  ->method('getEntityManager')
61
                  ->willReturn($entityManager);
62
63
        Counter::getNext();
64
65
        $eventRecorder->onFlush($eventArgs);
66
67
        self::assertEquals(0, Counter::getNext());
68
    }
69
70
    /**
71
     * @return mixed[] array
72
     */
73
    public function provideEventAwareChangedEntities(): array
74
    {
75
        $awareEntity = new class (new RandomDomainEvent()) implements EventAware {
76
            use EventsRegistry;
77
78
            public function __construct(DomainEvent $domainEvent)
79
            {
80
                $this->recordedEvents = [1 => $domainEvent, 0 => $domainEvent];
81
            }
82
        };
83
84
        return [
85
            'with no changed entities' => [new Object_(), []],
86
            'with a changed entity' => [$awareEntity, [new RandomDomainEvent(), new RandomDomainEvent()]],
87
        ];
88
    }
89
}
90