wiki.techinc.nl/tests/phpunit/includes/content/CssContentHandlerIntegrationTest.php
Timo Tijhof 64734f61ee content: Widen @covers tags in phpunit tests
https://gerrit.wikimedia.org/r/q/owner:Krinkle+is:merged+message:Widen

> Given all called methods are de-facto and liberally claimed, and
> that we keep the coverage limited to the subject class, it maintains
> the spirit and intent by listing the class explicitly instead.
>
> PHPUnit offers a more precise tool when you need it (i.e. when testing
> legacy monster/god classes), but for well-written code, the
> class-wide tag is exactly what you want.
>
> We lose useful coverage and waste valuable time on keeping tags
> accurate through refactors (or worse, forget to do so).
> Tracking tiny per-method details wastes time in realizing (and
> fixing) when people inevitably don't keep them in sync, and time
> lost in finding uncovered code to write tests to realize it was
> already covered but "not yet claimed".

While at it, also fix PHPUnit warnings in CssContentHandlerIntegrationTest
and JavaScriptContentHandlerIntegrationTest about not having any
`@covers` annotations.

Change-Id: I5afd9fe0bca0fa86cc096f6e5e79f2ba1cfbfa77
2024-07-21 21:03:10 +00:00

50 lines
1.2 KiB
PHP

<?php
/**
* @group ContentHandler
* @group Database
* ^--- needed, because we do need the database to test link updates
* @covers CssContentHandler
*/
class CssContentHandlerIntegrationTest extends TextContentHandlerIntegrationTest {
public static function provideGetParserOutput() {
yield 'Basic render' => [
'title' => 'MediaWiki:Test.css',
'model' => null,
'text' => "hello <world>x\n",
'expectedHtml' => "<pre class=\"mw-code mw-css\" dir=\"ltr\">\nhello &lt;world>x\n\n</pre>",
'expectedFields' => [
'Links' => [
],
'Sections' => [
],
],
];
yield 'Links' => [
'title' => 'MediaWiki:Test.css',
'model' => null,
'text' => "/* hello [[world]] */\n",
'expectedHtml' => "<pre class=\"mw-code mw-css\" dir=\"ltr\">\n/* hello [[world]] */\n\n</pre>",
'expectedFields' => [
'Links' => [
[ 'World' => 0, ],
],
'Sections' => [
],
],
];
yield 'TOC' => [
'title' => 'MediaWiki:Test.css',
'model' => null,
'text' => "==One==\n<h2>Two</h2>",
'expectedHtml' => "<pre class=\"mw-code mw-css\" dir=\"ltr\">\n==One==\n&lt;h2>Two&lt;/h2>\n</pre>",
'expectedFields' => [
'Links' => [
],
# T307691
'Sections' => [
],
]
];
}
}