wiki.techinc.nl/tests/phpunit/includes/logging/ImportLogFormatterTest.php
DannyS712 31676abea5 Add DummyServicesTrait::getDummyInterwikiLookup
Replacing the mock InterwikiLookup used in
MediaWikiTitleCodecTest revealed that that test was,
because of the mock not behaving correctly, testing the
wrong thing - interwiki prefixes are *not* case sensitive,
and are always converted to lowercase in the actual
ClassicInterwikiLookup. Fixed those expectations.

Change-Id: I242431e88860b7700a9f93f77a0fe195fd748800
2021-05-05 10:57:59 -07:00

122 lines
2.8 KiB
PHP

<?php
use MediaWiki\Tests\Unit\DummyServicesTrait;
/**
* @covers ImportLogFormatter
*/
class ImportLogFormatterTest extends LogFormatterTestCase {
use DummyServicesTrait;
/**
* Provide different rows from the logging table to test
* for backward compatibility.
* Do not change the existing data, just add a new database row
*/
public static function provideUploadLogDatabaseRows() {
return [
// Current format
[
[
'type' => 'import',
'action' => 'upload',
'comment' => 'upload comment',
'namespace' => NS_MAIN,
'title' => 'ImportPage',
'params' => [
'4:number:count' => '1',
],
],
[
'text' => 'User imported ImportPage by file upload (1 revision)',
'api' => [
'count' => 1,
],
],
],
// old format - without details
[
[
'type' => 'import',
'action' => 'upload',
'comment' => '1 revision: import comment',
'namespace' => NS_MAIN,
'title' => 'ImportPage',
'params' => [],
],
[
'text' => 'User imported ImportPage by file upload',
'api' => [],
],
],
];
}
/**
* @dataProvider provideUploadLogDatabaseRows
*/
public function testUploadLogDatabaseRows( $row, $extra ) {
$this->doTestLogFormatter( $row, $extra );
}
/**
* Provide different rows from the logging table to test
* for backward compatibility.
* Do not change the existing data, just add a new database row
*/
public static function provideInterwikiLogDatabaseRows() {
return [
// Current format
[
[
'type' => 'import',
'action' => 'interwiki',
'comment' => 'interwiki comment',
'namespace' => NS_MAIN,
'title' => 'ImportPage',
'params' => [
'4:number:count' => '1',
'5:title-link:interwiki' => 'importiw:PageImport',
],
],
[
'text' => 'User imported ImportPage from importiw:PageImport (1 revision)',
'api' => [
'count' => 1,
'interwiki_ns' => 0,
'interwiki_title' => 'importiw:PageImport',
],
],
],
// old format - without details
[
[
'type' => 'import',
'action' => 'interwiki',
'comment' => '1 revision from importiw:PageImport: interwiki comment',
'namespace' => NS_MAIN,
'title' => 'ImportPage',
'params' => [],
],
[
'text' => 'User imported ImportPage from another wiki',
'api' => [],
],
],
];
}
/**
* @dataProvider provideInterwikiLogDatabaseRows
*/
public function testInterwikiLogDatabaseRows( $row, $extra ) {
// Setup importiw: as interwiki prefix
// DummyServicesTrait::getDummyInterwikiLookup
$interwikiLookup = $this->getDummyInterwikiLookup( [ 'importiw' ] );
$this->setService( 'InterwikiLookup', $interwikiLookup );
$this->doTestLogFormatter( $row, $extra );
}
}