Migration plugin throws PHP type error

Created on 26 January 2023, about 2 years ago
Updated 27 January 2023, about 2 years ago

Problem/Motivation

When using the migration plugin the following error is logged:
[ERROR] [php] TypeError: Drupal\flush_single_image\Plugin\migrate\process\FlushSingleImage::__construct(): Argument #4 ($flushSingleImageService) must be of type Drupal\flush_single_image\Plugin\migrate\process\FlushSingleImage, Drupal\flush_single_image\FlushSingleImage given
Migration fails.

Steps to reproduce

Install module, use the flush_single_image plugin.

Proposed resolution

Update argument type in __construct().

Remaining tasks

/

User interface changes

/

API changes

/

Data model changes

/

🐛 Bug report
Status

Fixed

Version

2.0

Component

Code

Created by

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

Comments & Activities

  • Issue created by @chlandin
  • 🇨🇦Canada geoanders Nova Scotia 🍁
  • Status changed to Needs review about 2 years ago
  • 🇨🇦Canada geoanders Nova Scotia 🍁

    @chlandin

    Please see attached patch. Let me know if this works for you.

    Thanks,
    George

  • Thanks for the quick reply @geoanders.

    I'm afraid your patch is not compatible with version 2.3 that I got via composer require.
    If you look here you can see that all arguments in __construct() are on the same line.

  • Thanks for the quick reply @geoanders.

    I'm afraid your patch is not compatible with version 2.3 that I got via composer require.
    If you look here you can see that all arguments in __construct() are on the same line.

  • Thanks for the quick reply @geoanders.

    I'm afraid your patch is not compatible with version 2.3 that I got via composer require.
    If you look here you can see that all arguments in __construct() are on the same line.

    If I update the constructor to public function __construct(array $configuration, $plugin_id, $plugin_definition, \Drupal\flush_single_image\FlushSingleImage $flushSingleImageService) { I can run the migration locally. Is there a naming problem perhaps?

  • Here is a patch against 8.x-2.3 in case anyone else runs into this issue.

  • 🇨🇦Canada geoanders Nova Scotia 🍁

    It's because of the class names for both the service and migrate plugin. They clash since their name is the same but are in different namespaces.

    Thanks for the patch. I was working against latest dev branch. The fix or logic behind it should still apply.

  • Status changed to Fixed about 2 years ago
  • 🇨🇦Canada geoanders Nova Scotia 🍁
  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024