Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unit test classes should be declared as either final or abstract #103

Merged
merged 1 commit into from
Feb 18, 2024

Conversation

andrewnicols
Copy link
Contributor

@andrewnicols andrewnicols commented Feb 14, 2024

Fixes #102

The rationale for this change is based on the principle of least astonishment.

  • If I modify a unit test, I expect it to only impact the thing that I expect it to test. If I add a new test, it should only test the thing I expect it to test.
  • If someone is extending my unit test, then that is no longer the case, and I may be testing things which I did not intend, or over-testing the same thing.

To solve this the idea is:

  • If I intend a test to be consumed, then I should make it abstract and I should extend it myself for my specific use-case.
  • If I do not intend a test to be extended, then it should be declared final

Copy link

codecov bot commented Feb 14, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Comparison is base (da7aa56) 96.57% compared to head (b8f9eee) 96.73%.

Additional details and impacted files
@@             Coverage Diff              @@
##               main     #103      +/-   ##
============================================
+ Coverage     96.57%   96.73%   +0.16%     
- Complexity      557      586      +29     
============================================
  Files            24       26       +2     
  Lines          1547     1625      +78     
============================================
+ Hits           1494     1572      +78     
  Misses           53       53              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@andrewnicols andrewnicols force-pushed the phpunit_final_test_classes branch from 48641b1 to ec33ecb Compare February 14, 2024 05:06
@andrewnicols andrewnicols self-assigned this Feb 14, 2024
@andrewnicols andrewnicols force-pushed the phpunit_final_test_classes branch from ec33ecb to c49ee0e Compare February 14, 2024 05:30
@stronk7
Copy link
Member

stronk7 commented Feb 14, 2024

Apart from the detail in the review, surely the major "problem" of this nice Sniff is to determine how do we apply it (only for X.Y and up, warning and error in 1-year, only for non-plugins, ...).

As far as it's not part of the coding-style neither enforced by PHPUnit incoming versions... we need to be careful about it (back to the discussion happening @ #92).

Ciao :-)

@stronk7 stronk7 added the enhancement New feature or request label Feb 15, 2024
@stronk7 stronk7 linked an issue Feb 15, 2024 that may be closed by this pull request
@andrewnicols andrewnicols force-pushed the phpunit_final_test_classes branch from c49ee0e to 74f10d4 Compare February 15, 2024 14:56
@andrewnicols
Copy link
Contributor Author

Okay,

I've:

  • split this into two sniffs:
    • one for tests which makes them final
    • one for testcases which makes them abstract
  • applied it to 4.4 and up only

I think we need to add this to the epic for PHPUnit 10 as a part of that puzzle and add it to our coding style. This isn't something radical.

@andrewnicols andrewnicols force-pushed the phpunit_final_test_classes branch from 74f10d4 to 776f92a Compare February 15, 2024 15:00
@stronk7
Copy link
Member

stronk7 commented Feb 15, 2024

For fixtures...

moodle/Tests/Sniffs/PHPUnit/fixtures

or

moodle/Tests/fixtures/PHPUnit

I've been doing the later lately and it seems that you've been doing the former. Of course, there are still a lot of fixtures to move so, at some time, we should decide which of the 2 fixtures dirs to use and go for it everywhere (for testing own Sniffs, other standards sniffs are another story).

Copy link
Member

@stronk7 stronk7 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The final question in the review here is... do we want this to start warning now, with 4.4dev? Or want it for the next one?

@andrewnicols
Copy link
Contributor Author

For fixtures...

moodle/Tests/Sniffs/PHPUnit/fixtures

or

moodle/Tests/fixtures/PHPUnit

I've been doing the later lately and it seems that you've been doing the former. Of course, there are still a lot of fixtures to move so, at some time, we should decide which of the 2 fixtures dirs to use and go for it everywhere (for testing own Sniffs, other standards sniffs are another story).

I've been doing the former because it keeps the fixtures closer to the thing under test, and makes them easier to find, but I'm happy to move them. Let me know your preference.

@andrewnicols andrewnicols force-pushed the phpunit_final_test_classes branch from 776f92a to 102401f Compare February 16, 2024 01:37
@stronk7
Copy link
Member

stronk7 commented Feb 16, 2024

I've been doing the former because it keeps the fixtures closer to the thing under test, and makes them easier to find, but I'm happy to move them. Let me know your preference.

Yeah, I think I agree with you, let's keep the fixtures closer to the the Test using them, specially now that we are creating subdirs for the tests.

Not in a hurry to move all current ones that have followed other paths, but let's go with your alternative for new ones.

@stronk7
Copy link
Member

stronk7 commented Feb 16, 2024

So, just to be 100% sure, as commented above:

  • The final question in the review here is... do we want this to start warning now, with 4.4dev? Or want it for the next one?
  • It will apply to all code checked (core and plugins).

I'm happy with that (4.4dev), will generate some noise for plugins, but it's a good thing, I think. And prepares us for the future, together with #106 and other details that have arrived recently (static providers, ....).

So, with your 👍 , agreement!

@andrewnicols andrewnicols force-pushed the phpunit_final_test_classes branch from 102401f to b8f9eee Compare February 17, 2024 05:11
@stronk7
Copy link
Member

stronk7 commented Feb 18, 2024

Sold!

@stronk7 stronk7 merged commit 73f0a60 into moodlehq:main Feb 18, 2024
8 checks passed
stronk7 added a commit to stronk7/moodle-cs that referenced this pull request Feb 19, 2024
The base dir for the tests must be Tests/Util and
all its fixtures must be together in Tests/Util/fixtures dir.

Agreed @ moodlehq#103 (comment)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
2 participants