Cleanup real files in KernelTestBase tests

Created on 22 October 2024, 6 months ago

Problem/Motivation

Some kernel tests override \Drupal\KernelTests\KernelTestBase::setUpFilesystem() to use a real file system for testing things that cannot be tested on vfs. For example any test that extends \Drupal\KernelTests\Core\File\FileTestBase. These tests do not currently clean-up after themselves. This was noted in πŸ› Symlinking a module breaks HookCollectorPass Active

Steps to reproduce

Run \Drupal\KernelTests\Core\Archiver\ZipTest and see the directory left in sites/simpletest

Proposed resolution

Add functionality to KernelTestBase to do the cleanup if necessary and fix deleteRecursive to work with symlinks correctly.

Remaining tasks

User interface changes

N/a

Introduced terminology

N/a

API changes

N/a

Data model changes

N/a

Release notes snippet

N/a

πŸ› Bug report
Status

Active

Version

11.0 πŸ”₯

Component

phpunit

Created by

πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

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

Merge Requests

Comments & Activities

  • Issue created by @alexpott
  • πŸ‡ΊπŸ‡ΈUnited States nicxvan

    Do we want a flag to allow them to stay for local debugging if you need to see the actual files created for some reason?
    And maybe a way to confirm that cleanup happened so future tests have to clean up after themselves.

  • Merge request !9905Resolve #3482449 "Cleanup real files" β†’ (Closed) created by alexpott
  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    @nicxvan no - we don't offer that in WebDriverTestBase which does the same thing. You can always preserve the environment by adding an exit() to the test.

    FWIW the fix to \Drupal\Core\File\FileSystem::deleteRecursive() almost makes me want to make this issue about that and not KTB and tidying up. This feels like a serious data destruction bug - we should not be recursing into links and removing files...

  • πŸ‡ΊπŸ‡ΈUnited States nicxvan

    exit() makes sense, my only thought was sometimes you might need to see more broadly, but that is probably super edge case and not worth the effort.

  • Pipeline finished with Canceled
    6 months ago
    Total: 925s
    #317107
  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    Changing the focus of the issue to be the data loss bug discovered here by trying to cleanup the new \Drupal\KernelTests\Core\Hook\HookCollectorPassTest::testSymlink() test.

  • Pipeline finished with Success
    6 months ago
    Total: 3190s
    #317131
  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    I extended test coverage to include links to files outside of the directory being deleted. This is not currently broken but it feels good to have a test for.

  • Pipeline finished with Success
    6 months ago
    Total: 496s
    #317320
  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    So added some test coverage of the expanded delete functionality. Which opens up more worms because of the way that streams work with links and resolve to the real file or directory and not link. Which imo results in very odd behaviour when you call delete.

  • Pipeline finished with Success
    6 months ago
    Total: 8061s
    #317985
  • πŸ‡ΊπŸ‡ΈUnited States nicxvan

    I took a look at this again, it seems pretty straightforward.

    The only question I have is this worth a comment mentioning the risk to consider if this gets changed in the future?
    Unless you think the comment for the tests is enough: Tests symlinks in directories do not result in unexpected deletions.
    It might be helpful for people using this as example code for themselves to see what to consider.

  • πŸ‡¬πŸ‡§United Kingdom alexpott πŸ‡ͺπŸ‡ΊπŸŒ

    @nicxvan I think the additional test coverage added here is fine.

  • First commit to issue fork.
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    Rebased because it was 190 commits back.

    Funny I got 6 random errors bur re-running twice fixed those

    All the new tests appear to fail in the test-only job https://git.drupalcode.org/issue/drupal-3482449/-/jobs/3688988

    Dont't see any open threads believe this is good.

    • catch β†’ committed addee909 on 10.5.x
      Issue #3482449 by alexpott, smustgrave, nicxvan: \Drupal\Core\File\...
    • catch β†’ committed ed78b812 on 11.x
      Issue #3482449 by alexpott, smustgrave, nicxvan: \Drupal\Core\File\...
  • πŸ‡¬πŸ‡§United Kingdom catch

    Committed/pushed to 11.x and cherry-picked to 10.5.x, thanks!

  • Status changed to Fixed about 2 months ago
  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024