diff --git a/eZ/Publish/API/Repository/Tests/LocationServiceTest.php b/eZ/Publish/API/Repository/Tests/LocationServiceTest.php index 8b321dc18b5..b5f898d7742 100644 --- a/eZ/Publish/API/Repository/Tests/LocationServiceTest.php +++ b/eZ/Publish/API/Repository/Tests/LocationServiceTest.php @@ -2520,6 +2520,49 @@ public function testCopySubtreeIncrementsChildCountOfNewParent() $this->assertEquals($childCountBefore + 1, $childCountAfter); } + /** + * @covers \eZ\Publish\API\Repository\LocationService::copySubtree() + */ + public function testCopySubtreeWithInvisibleChild(): void + { + $repository = $this->getRepository(); + $locationService = $repository->getLocationService(); + + // Hide child Location + $locationService->hideLocation($locationService->loadLocation($this->generateId('location', 53))); + + $this->refreshSearch($repository); + + $locationToCopy = $locationService->loadLocation($this->generateId('location', 43)); + + $expected = $this->loadSubtreeProperties($locationToCopy); + + $mediaLocationId = $this->generateId('location', 43); + $demoDesignLocationId = $this->generateId('location', 56); + $locationService = $repository->getLocationService(); + + $locationToCopy = $locationService->loadLocation($mediaLocationId); + + $newParentLocation = $locationService->loadLocation($demoDesignLocationId); + + $copiedLocation = $locationService->copySubtree( + $locationToCopy, + $newParentLocation + ); + + $this->refreshSearch($repository); + + // Load Subtree properties after copy + $actual = $this->loadSubtreeProperties($copiedLocation); + + self::assertEquals(count($expected), count($actual)); + + foreach ($actual as $key => $properties) { + self::assertEquals($expected[$key]['hidden'], $properties['hidden']); + self::assertEquals($expected[$key]['invisible'], $properties['invisible']); + } + } + /** * Test for the copySubtree() method. * diff --git a/eZ/Publish/Core/Persistence/Legacy/Content/Location/Handler.php b/eZ/Publish/Core/Persistence/Legacy/Content/Location/Handler.php index 6c2fffd06f3..9e7d18f4ece 100644 --- a/eZ/Publish/Core/Persistence/Legacy/Content/Location/Handler.php +++ b/eZ/Publish/Core/Persistence/Legacy/Content/Location/Handler.php @@ -287,7 +287,10 @@ public function copySubtree($sourceId, $destinationParentId, $newOwnerId = null) $createStruct->contentId = $contentMap[$child['contentobject_id']]; $parentData = $locationMap[$child['parent_node_id']]; $createStruct->parentId = $parentData['id']; - $createStruct->invisible = $createStruct->hidden || $parentData['hidden'] || $parentData['invisible']; + $createStruct->invisible = $createStruct->invisible + || $createStruct->hidden + || $parentData['hidden'] + || $parentData['invisible']; $pathString = explode('/', $child['path_identification_string']); $pathString = end($pathString); $createStruct->pathIdentificationString = strlen($pathString) > 0