diff --git a/tests/lib/Event/TrashServiceTest.php b/tests/lib/Event/TrashServiceTest.php index 688926d049..c2c7945887 100644 --- a/tests/lib/Event/TrashServiceTest.php +++ b/tests/lib/Event/TrashServiceTest.php @@ -218,6 +218,41 @@ public function testTrashStopPropagationInBeforeEvents() ]); } + public function testTrashStopPropagationInBeforeEventsSetNullResult(): void + { + $traceableEventDispatcher = $this->getEventDispatcher( + BeforeTrashEvent::class, + TrashEvent::class + ); + + $parameters = [ + $this->createMock(Location::class), + ]; + + $innerServiceMock = $this->createMock(TrashServiceInterface::class); + $innerServiceMock->expects(self::never())->method('trash'); + + $traceableEventDispatcher->addListener(BeforeTrashEvent::class, static function (BeforeTrashEvent $event) { + $event->setResult(null); + $event->stopPropagation(); + }, 10); + + $service = new TrashService($innerServiceMock, $traceableEventDispatcher); + $result = $service->trash(...$parameters); + + $calledListeners = $this->getListenersStack($traceableEventDispatcher->getCalledListeners()); + $notCalledListeners = $this->getListenersStack($traceableEventDispatcher->getNotCalledListeners()); + + $this->assertNull($result); + $this->assertSame($calledListeners, [ + [BeforeTrashEvent::class, 10], + ]); + $this->assertSame($notCalledListeners, [ + [BeforeTrashEvent::class, 0], + [TrashEvent::class, 0], + ]); + } + public function testRecoverEvents() { $traceableEventDispatcher = $this->getEventDispatcher(