Add kernel tests for prefixing of migrate process errors

Created on 8 November 2023, about 1 year ago
Updated 25 January 2024, 11 months ago

Problem/Motivation

When a migration process plugin throws an exception, the migrate system prefixes the message with the migration ID and the process plugin ID. This is done so that when the developer reads the message in the map, they can understand where it came from.

Issues such as πŸ› Exception message in subprocess doesn't say which property in the subprocess was affected Needs work have shown that there isn't actually any test coverage of this functionality.

Steps to reproduce

Proposed resolution

MR5462 is to be used

Other MR can be closed

Remaining tasks

User interface changes

API changes

Data model changes

Release notes snippet

πŸ“Œ Task
Status

Fixed

Version

10.2 ✨

Component
MigrationΒ  β†’

Last updated about 12 hours ago

Created by

πŸ‡¬πŸ‡§United Kingdom joachim

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

Merge Requests

Comments & Activities

  • Issue created by @joachim
  • πŸ‡¬πŸ‡§United Kingdom joachim

    Working on this.

  • Status changed to Needs review about 1 year ago
  • πŸ‡¬πŸ‡§United Kingdom joachim

    Working test pushed to 3400189-add-kernel-tests-migrate-process-errors.

    WIP for subprocess message test pushed to sandbox-3400189-subprocess-test because I can't get it to work and have probably done something stupid.

  • Issue was unassigned.
  • πŸ‡¬πŸ‡§United Kingdom joachim
  • Status changed to Needs work about 1 year ago
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Is MR suppose to be in draft?

    Seems to have failed cspell.

  • Status changed to Needs review about 1 year ago
  • πŸ‡¬πŸ‡§United Kingdom joachim

    It's in draft because I'm stuck on the second part of what I want to test, which is in the sanbox branch -- see my earlier comment. Review of the direction I've taken so far would be helpful.

  • Status changed to Needs work about 1 year ago
  • The Needs Review Queue Bot β†’ tested this issue. It fails the Drupal core commit checks. Therefore, this issue status is now "Needs work".

    This does not mean that the patch needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide β†’ to find step-by-step guides for working with issues.

  • Status changed to Needs review about 1 year ago
  • πŸ‡¬πŸ‡§United Kingdom joachim

    Fixed the tests.

  • Status changed to Needs work about 1 year ago
  • The Needs Review Queue Bot β†’ tested this issue. It fails the Drupal core commit checks. Therefore, this issue status is now "Needs work".

    This does not mean that the patch needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide β†’ to find step-by-step guides for working with issues.

  • Status changed to Needs review about 1 year ago
  • πŸ‡¬πŸ‡§United Kingdom joachim

    The NIghtwatch test can't be related to this -- this MR is only adding a Kernel test.

  • Status changed to RTBC about 1 year ago
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Circled back to this one and had to look at other migration kernel tests, mainly for the definition structure, and believe this is covering the feature. Going to mark and also post in #migration slack channel in case needs submaintainer sign off.

  • Status changed to Needs work about 1 year ago
  • πŸ‡ΊπŸ‡ΈUnited States mikelutz Michigan, USA
  • πŸ‡¬πŸ‡§United Kingdom joachim

    I don't think we should switch to using the core SQL ID map. It adds complexity to the test, because we have to remember what might be in the map already, and because we have to write queries. It also adds a performance cost.

    This sort of test is a clear case for a in-memory map - we collect the map messages, then get them out. This is the same pattern that tests use when checking log messages.

    I agree that I've not set up the map properly - that needs work.

  • Merge request !5462Resolve #3400189 "Test via prophecy" β†’ (Open) created by mikelutz
  • Status changed to Needs review about 1 year ago
  • πŸ‡ΊπŸ‡ΈUnited States mikelutz Michigan, USA

    I don't fully agree. If we were using the normal drupal logger, then yes, we can mock that in memory and it's fine. The idmap plugins are their own system, and the Sql Idmap is used 99.9% of the time. I feel like what you want to test here is what message actually makes it into the database, and I think that should include the system that is responsible for storing it in the database. I also don't think the performance costs of the the SQL plugin are significant compared to the costs of running a migration in the test, I feel the additional coverage of the system used to store the messages far outweighs the extra few clock cycles to include it.

    That said, I also don't mind keeping tests very specific and isolated. If the goal here is to test the message that gets passed to MigrateIdMapInterface::saveMessage() given a specific process exception thrown in a specific place, I fully support that. We have \Drupal\tests\Migrate\Unit\MigrateSqlIdMapTest::testMessageSave() to test that the message passed to saveMessage() is what makes it to the database.

    So if the goal is to test the argument passed to saveMessage is as expected given a process exception, lets do that directly using prophecies, rather than making. a new test module. I created a new MR using that approach. I prefer the prophecies to adding test modules when possible. While I admit this test comes close to the borderline where a complex prophecy setup might make me prefer a test module, it does not cross it for me. The benefit of having the entire test in one class makes this preferable, I believe.

  • πŸ‡¬πŸ‡§United Kingdom joachim

    > If the goal here is to test the message that gets passed to MigrateIdMapInterface::saveMessage() given a specific process exception thrown in a specific place,

    Yes, that's my intention here. I think we should have test coverage before tackling the two issues I filed about improving the detail that is added to process exception messages.

    I'm also in favour of prophecy over test code and keeping code in one place where possible - it didn't occur to me and also I don't know the class structure well enough.

  • πŸ‡ΊπŸ‡ΈUnited States mikelutz Michigan, USA

    Alright, I think we can close MR5299 and go with MR5462 for this issue then. Leaving as NR from NRQI.

  • Status changed to RTBC about 1 year ago
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Highlighted which MR is to be used in the issue summary.

    The switch to prophecy is very interesting! This should be bookmarked haha

    Nothing seemed to break and the coverage seems to be there.

  • πŸ‡¬πŸ‡§United Kingdom longwave UK

    Backported to 10.2.x as it's tests-only.

    Committed and pushed 021e0ede07 to 11.x and c2e01926b2 to 10.2.x. Thanks!

    • longwave β†’ committed c2e01926 on 10.2.x
      Issue #3400189 by joachim, mikelutz: Add kernel tests for prefixing of...
  • Status changed to Fixed 12 months ago
    • longwave β†’ committed 021e0ede on 11.x
      Issue #3400189 by joachim, mikelutz: Add kernel tests for prefixing of...
  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024