From 84a16b0d5c0c093314f53b80ff2ea59b555ee933 Mon Sep 17 00:00:00 2001 From: Nattfarinn Date: Thu, 25 Apr 2024 09:37:01 +0200 Subject: [PATCH] fix: Reorganize subscriber test --- .../ResolveVirtualFieldSubscriberTest.php | 227 +++++++++--------- 1 file changed, 108 insertions(+), 119 deletions(-) diff --git a/tests/lib/Persistence/Legacy/Content/Mapper/ResolveVirtualFieldSubscriberTest.php b/tests/lib/Persistence/Legacy/Content/Mapper/ResolveVirtualFieldSubscriberTest.php index 9a4cae3f2b..9f7fafff27 100644 --- a/tests/lib/Persistence/Legacy/Content/Mapper/ResolveVirtualFieldSubscriberTest.php +++ b/tests/lib/Persistence/Legacy/Content/Mapper/ResolveVirtualFieldSubscriberTest.php @@ -28,30 +28,9 @@ final class ResolveVirtualFieldSubscriberTest extends TestCase { - private function getContent(): Content - { - $versionInfo = $this->getVersionInfo(); - - $content = new Content(); - $content->versionInfo = $versionInfo; - $content->fields = []; - - return $content; - } - - private function getVersionInfo(): VersionInfo - { - $versionInfo = new VersionInfo(); - $versionInfo->versionNo = 123; - - return $versionInfo; - } - public function testResolveVirtualField(): void { - $converterRegistry = $this->createMock(ConverterRegistry::class); - $converterRegistry->method('getConverter') - ->willReturn($this->createMock(Converter::class)); + $converterRegistry = $this->getConverterRegistry(); $storageRegistry = $this->createMock(StorageRegistry::class); $storageRegistry->method('getStorage') @@ -61,31 +40,25 @@ public function testResolveVirtualField(): void $contentGateway->expects($this->never()) ->method('insertNewField'); - $eventDispatcher = $this->getEventDispatcher(); - $eventDispatcher->addSubscriber( - new ResolveVirtualFieldSubscriber( - $converterRegistry, - $storageRegistry, - $contentGateway - ) + $eventDispatcher = $this->getEventDispatcher( + $converterRegistry, + $storageRegistry, + $contentGateway ); - $content = $this->getContent(); - $fieldDefinition = new FieldDefinition([ - 'id' => 123, - 'identifier' => 'example_field', - 'fieldType' => 'some_type', - 'defaultValue' => new Content\FieldValue(), - ]); - - $event = new ResolveMissingFieldEvent( - $content, - $fieldDefinition, - 'eng-GB' + $event = $eventDispatcher->dispatch( + new ResolveMissingFieldEvent( + $this->getContent(), + new FieldDefinition([ + 'id' => 123, + 'identifier' => 'example_field', + 'fieldType' => 'some_type', + 'defaultValue' => new Content\FieldValue(), + ]), + 'eng-GB' + ) ); - $event = $eventDispatcher->dispatch($event); - $expected = new Content\Field([ 'id' => null, 'fieldDefinitionId' => 123, @@ -113,9 +86,7 @@ public function testResolveVirtualField(): void public function testResolveVirtualExternalStorageField(): void { - $converterRegistry = $this->createMock(ConverterRegistry::class); - $converterRegistry->method('getConverter') - ->willReturn($this->createMock(Converter::class)); + $converterRegistry = $this->getConverterRegistry(); $storageRegistry = $this->createMock(StorageRegistry::class); $storageRegistry->method('getStorage') @@ -158,31 +129,25 @@ public function getIndexData(VersionInfo $versionInfo, Field $field, array $cont $contentGateway->expects($this->never()) ->method('insertNewField'); - $eventDispatcher = $this->getEventDispatcher(); - $eventDispatcher->addSubscriber( - new ResolveVirtualFieldSubscriber( - $converterRegistry, - $storageRegistry, - $contentGateway - ) + $eventDispatcher = $this->getEventDispatcher( + $converterRegistry, + $storageRegistry, + $contentGateway ); - $content = $this->getContent(); - $fieldDefinition = new FieldDefinition([ - 'id' => 678, - 'identifier' => 'example_external_field', - 'fieldType' => 'external_type_virtual', - 'defaultValue' => new Content\FieldValue(), - ]); - - $event = new ResolveMissingFieldEvent( - $content, - $fieldDefinition, - 'eng-GB' + $event = $eventDispatcher->dispatch( + new ResolveMissingFieldEvent( + $this->getContent(), + new FieldDefinition([ + 'id' => 678, + 'identifier' => 'example_external_field', + 'fieldType' => 'external_type_virtual', + 'defaultValue' => new Content\FieldValue(), + ]), + 'eng-GB' + ) ); - $event = $eventDispatcher->dispatch($event); - $expected = new Content\Field([ 'id' => null, 'fieldDefinitionId' => 678, @@ -210,9 +175,7 @@ public function getIndexData(VersionInfo $versionInfo, Field $field, array $cont public function testPersistEmptyExternalStorageField(): void { - $converterRegistry = $this->createMock(ConverterRegistry::class); - $converterRegistry->method('getConverter') - ->willReturn($this->createMock(Converter::class)); + $converterRegistry = $this->getConverterRegistry(); $storage = $this->createMock(FieldStorage::class); $storage->expects($this->never()) @@ -235,31 +198,25 @@ public function testPersistEmptyExternalStorageField(): void ->method('insertNewField') ->willReturn(567); - $eventDispatcher = $this->getEventDispatcher(); - $eventDispatcher->addSubscriber( - new ResolveVirtualFieldSubscriber( - $converterRegistry, - $storageRegistry, - $contentGateway, - ) + $eventDispatcher = $this->getEventDispatcher( + $converterRegistry, + $storageRegistry, + $contentGateway ); - $content = $this->getContent(); - $fieldDefinition = new FieldDefinition([ - 'id' => 123, - 'identifier' => 'example_field', - 'fieldType' => 'external_type', - 'defaultValue' => new Content\FieldValue(), - ]); - - $event = new ResolveMissingFieldEvent( - $content, - $fieldDefinition, - 'eng-GB' + $event = $eventDispatcher->dispatch( + new ResolveMissingFieldEvent( + $this->getContent(), + new FieldDefinition([ + 'id' => 123, + 'identifier' => 'example_field', + 'fieldType' => 'external_type', + 'defaultValue' => new Content\FieldValue(), + ]), + 'eng-GB' + ) ); - $event = $eventDispatcher->dispatch($event); - $expected = new Content\Field([ 'id' => 567, 'fieldDefinitionId' => 123, @@ -291,9 +248,7 @@ public function testPersistEmptyExternalStorageField(): void public function testPersistExternalStorageField(): void { - $converterRegistry = $this->createMock(ConverterRegistry::class); - $converterRegistry->method('getConverter') - ->willReturn($this->createMock(Converter::class)); + $converterRegistry = $this->getConverterRegistry(); $storage = $this->createMock(FieldStorage::class); $storage->expects($this->once()) @@ -314,33 +269,27 @@ public function testPersistExternalStorageField(): void ->method('insertNewField') ->willReturn(456); - $eventDispatcher = $this->getEventDispatcher(); - $eventDispatcher->addSubscriber( - new ResolveVirtualFieldSubscriber( - $converterRegistry, - $storageRegistry, - $contentGateway, - ) + $eventDispatcher = $this->getEventDispatcher( + $converterRegistry, + $storageRegistry, + $contentGateway ); - $content = $this->getContent(); - $fieldDefinition = new FieldDefinition([ - 'id' => 123, - 'identifier' => 'example_field', - 'fieldType' => 'external_type', - 'defaultValue' => new Content\FieldValue([ - 'data' => ['some_data' => 'to_be_stored'], - ]), - ]); - - $event = new ResolveMissingFieldEvent( - $content, - $fieldDefinition, - 'eng-GB' + $event = $eventDispatcher->dispatch( + new ResolveMissingFieldEvent( + $this->getContent(), + new FieldDefinition([ + 'id' => 123, + 'identifier' => 'example_field', + 'fieldType' => 'external_type', + 'defaultValue' => new Content\FieldValue([ + 'data' => ['some_data' => 'to_be_stored'], + ]), + ]), + 'eng-GB' + ) ); - $event = $eventDispatcher->dispatch($event); - $expected = new Content\Field([ 'id' => 456, 'fieldDefinitionId' => 123, @@ -373,11 +322,51 @@ public function testPersistExternalStorageField(): void ); } - private function getEventDispatcher(): TraceableEventDispatcher + private function getContent(): Content { + $versionInfo = $this->getVersionInfo(); + + $content = new Content(); + $content->versionInfo = $versionInfo; + $content->fields = []; + + return $content; + } + + private function getVersionInfo(): VersionInfo + { + $versionInfo = new VersionInfo(); + $versionInfo->versionNo = 123; + + return $versionInfo; + } + + private function getEventDispatcher( + ConverterRegistry $converterRegistry, + StorageRegistry $storageRegistry, + ContentGateway $contentGateway + ): TraceableEventDispatcher { + $eventDispatcher = new EventDispatcher(); + $eventDispatcher->addSubscriber( + new ResolveVirtualFieldSubscriber( + $converterRegistry, + $storageRegistry, + $contentGateway, + ) + ); + return new TraceableEventDispatcher( - new EventDispatcher(), + $eventDispatcher, new Stopwatch() ); } + + private function getConverterRegistry(): ConverterRegistry + { + $converterRegistry = $this->createMock(ConverterRegistry::class); + $converterRegistry->method('getConverter') + ->willReturn($this->createMock(Converter::class)); + + return $converterRegistry; + } }