Incorrect typing for ContentExporterInterface::exportEntity

Created on 10 May 2022, almost 3 years ago
Updated 25 September 2024, 6 months ago

Problem/Motivation

We use drupal-check for many of our D9 projects and it's currently reporting an incompatibility between ContentExporterInterface::exportEntity and some of our custom code that generates snapshot updates. The interface typing expects an array to be returned from the function, but the implementation only ever returns the result of Yaml::encode, which always resolves to a string.
This is more a documentation fix than anything.

Steps to reproduce

  1. Create a project with content_sync as a dependency
  2. Write a 3rd party module using the following code
    $serializer_context = [];
    $exported_entity = \Drupal::service('content_sync.exporter')->exportEntity($entity, $serializer_context);
    

    where $entity implements ContentEntityInterface

  3. Pass $exported_entity into anything that takes a string
  4. Set up drupal-check to scan custom code

Proposed resolution

Update typing of ContentExporterInterface::exportEntity to return a string.

Remaining tasks

  • Patch to fix function docblock

API changes

None

Data model changes

None

🐛 Bug report
Status

Needs review

Version

4.0

Component

Export

Created by

🇦🇺Australia geoffreyr

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

Production build 0.71.5 2024