1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
|
<?php
use MediaWiki\Category\TrackingCategories;
use MediaWiki\Config\ServiceOptions;
use MediaWiki\Logger\LoggerFactory;
use MediaWiki\Page\PageReferenceValue;
use MediaWiki\Parser\ParserOutput;
/**
* @covers \MediaWiki\Parser\ParserOutput
* @covers \MediaWiki\Parser\CacheTime
* @group Database
* ^--- trigger DB shadowing because we are using Title magic
*/
class TrackingCategoriesTest extends MediaWikiLangTestCase {
/**
* @covers \MediaWiki\Category\TrackingCategories::addTrackingCategory
*/
public function testAddTrackingCategory() {
$services = $this->getServiceContainer();
$tc = new TrackingCategories(
new ServiceOptions(
TrackingCategories::CONSTRUCTOR_OPTIONS,
$services->getMainConfig()
),
$services->getNamespaceInfo(),
$services->getTitleParser(),
LoggerFactory::getInstance( 'TrackingCategories' )
);
$po = new ParserOutput;
$po->setUnsortedPageProperty( 'defaultsort', 'foobar' );
$page = PageReferenceValue::localReference( NS_USER, 'Testing' );
$tc->addTrackingCategory( $po, 'index-category', $page ); // from CORE_TRACKING_CATEGORIES
$tc->addTrackingCategory( $po, 'sitenotice', $page ); // should be "-", which is ignored
$tc->addTrackingCategory( $po, 'brackets-start', $page ); // invalid text
// TODO: assert proper handling of non-existing messages
$expected = wfMessage( 'index-category' )
->page( $page )
->inContentLanguage()
->text();
// Note that the DEFAULTSORT is applied when the category links table
// is updated, so 'foobar' does not appear in the CategoryMap here.
$expected = strtr( $expected, ' ', '_' );
$this->assertSame( [ $expected => '' ], $po->getCategoryMap() );
}
}
|