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
122 lines
2.8 KiB
PHP
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 );
|
|
}
|
|
}
|