mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Cite
synced 2024-12-01 01:56:20 +00:00
fb8494b4dd
This is a direct follow up for I6f05842 where we already started supporting dashes, but converted them to underscores. The only change in this patch is that the CSS class will use the message key as it is, without the dashes being converted to underscores. I added a test case specifically for this. Bug: T352676 Change-Id: Ic22e897c27b8371e3b1ed63932b619e7af71bd5c
119 lines
4.2 KiB
PHP
119 lines
4.2 KiB
PHP
<?php
|
|
|
|
namespace Cite\Tests\Unit;
|
|
|
|
use Cite\ErrorReporter;
|
|
use Cite\ReferenceMessageLocalizer;
|
|
use Language;
|
|
use MediaWiki\Message\Message;
|
|
use MediaWiki\Parser\Parser;
|
|
use ParserOptions;
|
|
|
|
/**
|
|
* @covers \Cite\ErrorReporter
|
|
* @license GPL-2.0-or-later
|
|
*/
|
|
class ErrorReporterTest extends \MediaWikiUnitTestCase {
|
|
|
|
/**
|
|
* @dataProvider provideErrors
|
|
*/
|
|
public function testPlain(
|
|
string $key,
|
|
string $expectedHtml,
|
|
?string $expectedCategory
|
|
) {
|
|
$language = $this->createLanguage();
|
|
$reporter = $this->createReporter( $language );
|
|
$mockParser = $this->createParser( $language, $expectedCategory );
|
|
$this->assertSame(
|
|
$expectedHtml,
|
|
$reporter->plain( $mockParser, $key, 'first param' ) );
|
|
}
|
|
|
|
public function testDisabledWrapperMessages() {
|
|
$language = $this->createLanguage();
|
|
$reporter = $this->createReporter( $language, true );
|
|
$mockParser = $this->createParser( $language );
|
|
$this->assertSame(
|
|
'<span class="warning mw-ext-cite-warning mw-ext-cite-warning-a" lang="qqx" ' .
|
|
'dir="rtl">(cite_warning_a)</span>',
|
|
$reporter->plain( $mockParser, 'cite_warning_a' )
|
|
);
|
|
}
|
|
|
|
public function testHalfParsed() {
|
|
$language = $this->createLanguage();
|
|
$reporter = $this->createReporter( $language );
|
|
$mockParser = $this->createParser( $language );
|
|
$this->assertSame(
|
|
'<span class="warning mw-ext-cite-warning mw-ext-cite-warning-example" lang="qqx" ' .
|
|
'dir="rtl">[(cite_warning|(cite_warning_example|first param))]</span>',
|
|
$reporter->halfParsed( $mockParser, 'cite_warning_example', 'first param' ) );
|
|
}
|
|
|
|
public static function provideErrors() {
|
|
return [
|
|
'Example error' => [
|
|
'key' => 'cite_error_example',
|
|
'expectedHtml' => '<span class="error mw-ext-cite-error" lang="qqx" dir="rtl">' .
|
|
'(cite_error|(cite_error_example|first param))</span>',
|
|
'expectedCategory' => 'cite-tracking-category-cite-error',
|
|
],
|
|
'Warning error' => [
|
|
'key' => 'cite_warning_example',
|
|
'expectedHtml' => '<span class="warning mw-ext-cite-warning mw-ext-cite-warning-example" lang="qqx" ' .
|
|
'dir="rtl">(cite_warning|(cite_warning_example|first param))</span>',
|
|
'expectedCategory' => null,
|
|
],
|
|
'Optional support for messages with dashes' => [
|
|
'key' => 'cite-warning-with-dashes',
|
|
'expectedHtml' => '<span class="warning mw-ext-cite-warning ' .
|
|
'mw-ext-cite-warning-with-dashes" lang="qqx" dir="rtl">' .
|
|
'(cite_warning|(cite-warning-with-dashes|first param))</span>',
|
|
'expectedCategory' => null,
|
|
],
|
|
];
|
|
}
|
|
|
|
private function createLanguage(): Language {
|
|
$language = $this->createNoOpMock( Language::class, [ 'getDir', 'getHtmlCode' ] );
|
|
$language->method( 'getDir' )->willReturn( 'rtl' );
|
|
$language->method( 'getHtmlCode' )->willReturn( 'qqx' );
|
|
return $language;
|
|
}
|
|
|
|
private function createReporter( Language $language, bool $disabled = false ): ErrorReporter {
|
|
$mockMessageLocalizer = $this->createMock( ReferenceMessageLocalizer::class );
|
|
$mockMessageLocalizer->method( 'msg' )->willReturnCallback(
|
|
function ( ...$args ) use ( $language, $disabled ) {
|
|
$message = $this->createMock( Message::class );
|
|
$message->method( 'isDisabled' )->willReturn( $disabled );
|
|
$message->method( 'getKey' )->willReturn( $args[0] );
|
|
$message->method( 'plain' )->willReturn( '(' . implode( '|', $args ) . ')' );
|
|
$message->method( 'inLanguage' )->with( $language )->willReturnSelf();
|
|
$message->method( 'getLanguage' )->willReturn( $language );
|
|
return $message;
|
|
}
|
|
);
|
|
|
|
return new ErrorReporter( $mockMessageLocalizer );
|
|
}
|
|
|
|
private function createParser( Language $language, string $expectedCategory = null ): Parser {
|
|
$parserOptions = $this->createMock( ParserOptions::class );
|
|
$parserOptions->method( 'getUserLangObj' )->willReturn( $language );
|
|
|
|
$parser = $this->createNoOpMock( Parser::class, [ 'addTrackingCategory', 'getOptions', 'recursiveTagParse' ] );
|
|
$parser->expects( $expectedCategory ? $this->once() : $this->never() )
|
|
->method( 'addTrackingCategory' )
|
|
->with( $expectedCategory );
|
|
$parser->method( 'getOptions' )->willReturn( $parserOptions );
|
|
$parser->method( 'recursiveTagParse' )->willReturnCallback(
|
|
static fn ( $content ) => '[' . $content . ']'
|
|
);
|
|
return $parser;
|
|
}
|
|
|
|
}
|