TestDiscovery expects @group annotations, fails with #[Group()] attributes

Created on 12 May 2024, 9 months ago

Problem/Motivation

TestDiscovery expects @group annotations, fails with #[Group()] attributes.

Proposed resolution

Refactor TestDiscovery. Possibly get rid of custom code and just rely on PHPUnit to discover tests (?)

Remaining tasks

User interface changes

API changes

Data model changes

Release notes snippet

📌 Task
Status

Active

Version

11.0 🔥

Component
PHPUnit 

Last updated 1 day ago

Created by

🇮🇹Italy mondrake 🇮🇹

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

Merge Requests

Comments & Activities

  • Issue created by @mondrake
  • 🇮🇹Italy mondrake 🇮🇹
  • Merge request !8054Closes #3446705 → (Open) created by mondrake
  • Pipeline finished with Failed
    9 months ago
    Total: 189s
    #171746
  • Pipeline finished with Failed
    9 months ago
    Total: 180s
    #171753
  • Pipeline finished with Failed
    9 months ago
    Total: 196s
    #171765
  • Pipeline finished with Failed
    9 months ago
    Total: 363s
    #171781
  • Pipeline finished with Failed
    9 months ago
    Total: 189s
    #171916
  • Pipeline finished with Failed
    9 months ago
    Total: 665s
    #171918
  • Status changed to Needs review 9 months ago
  • 🇮🇹Italy mondrake 🇮🇹

    Tests need fixing, but I think the concept is reviewable.

    Getting rid of custom code and just relying on PHPUnit to discover tests is a bit too far and actually PHPUnit itself only recently changed format for --list-tests-xml output, and modified test list filtering options, in PHPUnit 11.1. So better wait to be on that before trying it.

    For now just extended TestDiscovery to look into attributes of test classes, falling back to annotations if they do not exist (like PHPUnit itself is doing).

  • Pipeline finished with Failed
    9 months ago
    Total: 209s
    #172194
  • Pipeline finished with Failed
    9 months ago
    Total: 363s
    #172198
  • Pipeline finished with Failed
    9 months ago
    Total: 616s
    #172234
  • Pipeline finished with Failed
    8 months ago
    Total: 194s
    #172361
  • Pipeline finished with Failed
    8 months ago
    Total: 697s
    #172366
  • Pipeline finished with Failed
    8 months ago
    Total: 604s
    #172388
  • Pipeline finished with Failed
    8 months ago
    Total: 655s
    #172637
  • Pipeline finished with Success
    8 months ago
    Total: 1111s
    #173114
  • Pipeline finished with Failed
    8 months ago
    Total: 175s
    #173155
  • Pipeline finished with Failed
    8 months ago
    Total: 643s
    #173156
  • Pipeline finished with Failed
    8 months ago
    Total: 648s
    #173210
  • Pipeline finished with Failed
    8 months ago
    Total: 165s
    #173398
  • Pipeline finished with Failed
    8 months ago
    Total: 527s
    #173403
  • Pipeline finished with Failed
    8 months ago
    Total: 606s
    #173689
  • Pipeline finished with Success
    8 months ago
    Total: 665s
    #174240
  • 🇮🇹Italy mondrake 🇮🇹

    Tests are green now.

  • 🇮🇹Italy mondrake 🇮🇹

    Added draft CR.

  • Pipeline finished with Success
    8 months ago
    Total: 635s
    #174588
  • Pipeline finished with Failed
    8 months ago
    Total: 992s
    #175865
  • 🇮🇹Italy mondrake 🇮🇹

    FWIW, I am pretty close to have an alternative implementation using PHPStan's BetterReflection.

    This would have the benefit of not loading all test classes via PHP's Reflection.

    But two drawbacks:
    1) it will be much slower
    2) it would require, at least for now, 📌 Downgrade (temporarily) nikic/php-parser to ^4 Closed: won't fix

    I do not think that's worth doing. In the future, I'd suggest to switch TestDiscovery to get the test list by executing PHPUnit's CLI with the --list-tests-xml option and parsing the resulting XML. That would effectively mean delegating 'how' test classes are discovered entirely to PHPUnit, in a separate process so that PHP's own allocated memory allocated would not be a constraint (if it is right now, today, I doubt anyway).

  • Merge request !8125Resolve #3446705 "Using betterreflection" → (Open) created by mondrake
  • Pipeline finished with Failed
    8 months ago
    Total: 194s
    #176489
  • 🇫🇷France andypost

    Just a question why new conflict added to composer?

    "nikic/php-parser": ">=5"
  • 🇮🇹Italy mondrake 🇮🇹

    MR!8054 uses PHP reflection.

    MR!8125 implements #7, uses BetterReflection (static reflection, no class loading in memory), and requires downgrading nikic/php-parser to 4, for the reasons discussed in 📌 Downgrade (temporarily) nikic/php-parser to ^4 Closed: won't fix .

    We need to decide on which horse to bet.

  • Pipeline finished with Failed
    8 months ago
    #176491
  • 🇫🇷France andypost

    As I get https://github.com/Roave/BetterReflection/pull/1387 already fixed and BetterReflection should work with v5 too

  • Status changed to Needs work 8 months ago
  • The Needs Review Queue Bot tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily 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 8 months ago
  • 🇮🇹Italy mondrake 🇮🇹

    Can I ask, please, to get a review of the two options and guidance on which one (or others) to follow? Not very keen in keeeping two alternative approaches rebased just to keep the NR; the second option would require rebasing anytime a dependency is bumped.

  • Pipeline finished with Success
    8 months ago
    Total: 608s
    #177967
  • Pipeline finished with Success
    8 months ago
    Total: 604s
    #185104
  • Pipeline finished with Success
    8 months ago
    Total: 499s
    #196379
  • Pipeline finished with Failed
    7 months ago
    Total: 296s
    #214226
  • 🇮🇹Italy mondrake 🇮🇹

    Rebased MR!8054

  • 🇮🇹Italy mondrake 🇮🇹
  • Pipeline finished with Success
    7 months ago
    Total: 517s
    #214227
  • Pipeline finished with Failed
    6 months ago
    Total: 121s
    #236502
  • 🇮🇹Italy mondrake 🇮🇹

    Rebased MR!8054

  • 🇮🇹Italy mondrake 🇮🇹

    Rebased, and fixed for new CS rules

  • Pipeline finished with Success
    6 months ago
    #246825
  • Pipeline finished with Success
    6 months ago
    Total: 513s
    #248268
  • Pipeline finished with Canceled
    5 months ago
    Total: 423s
    #271944
  • Pipeline finished with Success
    5 months ago
    Total: 512s
    #271948
  • 🇮🇹Italy mondrake 🇮🇹

    mondrake changed the visibility of the branch 3446705-using-BetterReflection to hidden.

  • 🇮🇹Italy mondrake 🇮🇹

    Rebased 8054, and hidden 8125.

  • Pipeline finished with Canceled
    5 months ago
    Total: 477s
    #273148
  • Pipeline finished with Success
    5 months ago
    Total: 658s
    #273155
  • 🇮🇹Italy mondrake 🇮🇹

    .

  • 🇺🇸United States smustgrave

    Should all @group annotations be replaced here?

  • 🇮🇹Italy mondrake 🇮🇹

    No, there are thousands, will have to happen in follow ups… they will have to go before we bump PHPUnit to 11, though.

    Here we are only allowing run-test.sh to find test defined by Group attributes along with those defined by @group annotations. So we can migrate bit by bit.

  • 🇮🇹Italy mondrake 🇮🇹

    The first follow up, to break the ice, would be 📌 Convert test annotation to attributes in Drupal/Test/Component Needs work

  • Pipeline finished with Failed
    4 months ago
    Total: 628s
    #291681
  • Pipeline finished with Success
    4 months ago
    Total: 2466s
    #300978
  • Pipeline finished with Failed
    3 months ago
    Total: 923s
    #320858
  • Status changed to Needs work 2 months ago
  • 🇬🇧United Kingdom catch

    This could use an issue summary update and a change record to indicate that attributes will be supported. We'll need to decide if we backport this to 10.x so that contrib tests using group attributes, I think that has to be a yes if we want people to use it.

    Also should we have a follow-up to try to use phpunit's discovery or did you end up deciding that's too far off?

  • 🇮🇹Italy mondrake 🇮🇹

    @catch

    backport this to 10.x

    can't do that alas - attributes are a PHPUnit 10+ thing, and D10 is testing with PHPUnit 9.

    should we have a follow-up to try to use phpunit's discovery or did you end up deciding that's too far off

    1. Must do prerequisite is 🐛 Ensure run-tests.sh and PHPUnit CLI run with the same list of tests to be executed Active to make sure we are testing the same things
    2. It's not far ( 📌 Refactor PhpUnitTestRunner and TestRun internal classes Active latest revision is doing that already), but it's ... slow. The logic in that issue is to run PHPUnit's CLI to build the test list in a xml file, then parse that file to build the internal list in PHP. That takes time, also considering that PHPUnit invokes dataproviders to build the full testcases list. It's not dramatic in CI context but locally the difference is visible.
  • 🇬🇧United Kingdom catch

    can't do that alas - attributes are a PHPUnit 10+ thing, and D10 is testing with PHPUnit 9.

    But if we're doing the discovery, does PHPUnit 9 care? (apologies if this is a silly question). Is the problem that the attribute class wouldn't exist?

  • 🇮🇹Italy mondrake 🇮🇹

    Just noticed CR is there already, https://www.drupal.org/node/3447698; please review

  • Pipeline finished with Success
    2 months ago
    Total: 946s
    #342505
  • 🇮🇹Italy mondrake 🇮🇹

    #28 actually that's true: https://www.drupal.org/project/drupal/issues/3445106#comment-15587547 📌 Replace @dataProvider annotations with #[DataProvider()] attributes Postponed you can have attributes and annotations in the same test in PHPUnit 9, apparently. Need probably to decide what to use where though, to avoid duplication and possible mistakes.

  • 🇮🇹Italy mondrake 🇮🇹

    Re #26 I think now we have the tools to do a

    follow-up to try to use phpunit's discovery

    see 📌 Deprecate TestDiscovery test file scanning, use PHPUnit API instead Active . That is an alternative approach to the one here, and simpler.

  • 🇮🇹Italy mondrake 🇮🇹

    I think 📌 Deprecate TestDiscovery test file scanning, use PHPUnit API instead Active is better than this, and this is now just a duplicate. Feel free to reopen in case of disagreement.

Production build 0.71.5 2024