This introduces the ContentHandler facility into MediaWiki, see docs/contenthandler.txt. For convenient review, a squashed version is available at https://gerrit.wikimedia.org/r/27191 The ContentHandler facility is a major building block of the Wikidata project. It has been discussed repeatedly on wikitech-l. Change-Id: I3804e2d5f6f59e6a39db80744bdf61bfe8c14f98
91 lines
2.6 KiB
PHP
91 lines
2.6 KiB
PHP
<?php
|
|
|
|
class ArticleTest extends MediaWikiTestCase {
|
|
|
|
/**
|
|
* @var Title
|
|
*/
|
|
private $title;
|
|
/**
|
|
* @var Article
|
|
*/
|
|
private $article;
|
|
|
|
/** creates a title object and its article object */
|
|
protected function setUp() {
|
|
$this->title = Title::makeTitle( NS_MAIN, 'SomePage' );
|
|
$this->article = new Article( $this->title );
|
|
|
|
}
|
|
|
|
/** cleanup title object and its article object */
|
|
protected function tearDown() {
|
|
$this->title = null;
|
|
$this->article = null;
|
|
|
|
}
|
|
|
|
function testImplementsGetMagic() {
|
|
$this->assertEquals( false, $this->article->mLatest, "Article __get magic" );
|
|
}
|
|
|
|
/**
|
|
* @depends testImplementsGetMagic
|
|
*/
|
|
function testImplementsSetMagic() {
|
|
$this->article->mLatest = 2;
|
|
$this->assertEquals( 2, $this->article->mLatest, "Article __set magic" );
|
|
}
|
|
|
|
/**
|
|
* @depends testImplementsSetMagic
|
|
*/
|
|
function testImplementsCallMagic() {
|
|
$this->article->mLatest = 33;
|
|
$this->article->mDataLoaded = true;
|
|
$this->assertEquals( 33, $this->article->getLatest(), "Article __call magic" );
|
|
}
|
|
|
|
function testGetOrSetOnNewProperty() {
|
|
$this->article->ext_someNewProperty = 12;
|
|
$this->assertEquals( 12, $this->article->ext_someNewProperty,
|
|
"Article get/set magic on new field" );
|
|
|
|
$this->article->ext_someNewProperty = -8;
|
|
$this->assertEquals( -8, $this->article->ext_someNewProperty,
|
|
"Article get/set magic on update to new field" );
|
|
}
|
|
|
|
/**
|
|
* Checks for the existence of the backwards compatibility static functions (forwarders to WikiPage class)
|
|
*/
|
|
function testStaticFunctions() {
|
|
$this->hideDeprecated( 'Article::getAutosummary' );
|
|
$this->hideDeprecated( 'WikiPage::getAutosummary' );
|
|
|
|
$this->assertEquals( WikiPage::selectFields(), Article::selectFields(),
|
|
"Article static functions" );
|
|
$this->assertEquals( true, is_callable( "Article::onArticleCreate" ),
|
|
"Article static functions" );
|
|
$this->assertEquals( true, is_callable( "Article::onArticleDelete" ),
|
|
"Article static functions" );
|
|
$this->assertEquals( true, is_callable( "ImagePage::onArticleEdit" ),
|
|
"Article static functions" );
|
|
$this->assertTrue( is_string( CategoryPage::getAutosummary( '', '', 0 ) ),
|
|
"Article static functions" );
|
|
}
|
|
|
|
function testWikiPageFactory() {
|
|
$title = Title::makeTitle( NS_FILE, 'Someimage.png' );
|
|
$page = WikiPage::factory( $title );
|
|
$this->assertEquals( 'WikiFilePage', get_class( $page ) );
|
|
|
|
$title = Title::makeTitle( NS_CATEGORY, 'SomeCategory' );
|
|
$page = WikiPage::factory( $title );
|
|
$this->assertEquals( 'WikiCategoryPage', get_class( $page ) );
|
|
|
|
$title = Title::makeTitle( NS_MAIN, 'SomePage' );
|
|
$page = WikiPage::factory( $title );
|
|
$this->assertEquals( 'WikiPage', get_class( $page ) );
|
|
}
|
|
}
|