Extensions sometimes need to stash information in the ParserOutput for later use. This change provides a clean way to do that. Change-Id: I8bc571d13c9a70bb71430862c2ab679ff1947126
55 lines
2 KiB
PHP
55 lines
2 KiB
PHP
<?php
|
|
|
|
class ParserOutputTest extends MediaWikiTestCase {
|
|
|
|
function dataIsLinkInternal() {
|
|
return array(
|
|
// Different domains
|
|
array( false, 'http://example.org', 'http://mediawiki.org' ),
|
|
// Same domains
|
|
array( true, 'http://example.org', 'http://example.org' ),
|
|
array( true, 'https://example.org', 'https://example.org' ),
|
|
array( true, '//example.org', '//example.org' ),
|
|
// Same domain different cases
|
|
array( true, 'http://example.org', 'http://EXAMPLE.ORG' ),
|
|
// Paths, queries, and fragments are not relevant
|
|
array( true, 'http://example.org', 'http://example.org/wiki/Main_Page' ),
|
|
array( true, 'http://example.org', 'http://example.org?my=query' ),
|
|
array( true, 'http://example.org', 'http://example.org#its-a-fragment' ),
|
|
// Different protocols
|
|
array( false, 'http://example.org', 'https://example.org' ),
|
|
array( false, 'https://example.org', 'http://example.org' ),
|
|
// Protocol relative servers always match http and https links
|
|
array( true, '//example.org', 'http://example.org' ),
|
|
array( true, '//example.org', 'https://example.org' ),
|
|
// But they don't match strange things like this
|
|
array( false, '//example.org', 'irc://example.org' ),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test to make sure ParserOutput::isLinkInternal behaves properly
|
|
* @dataProvider dataIsLinkInternal
|
|
*/
|
|
function testIsLinkInternal( $shouldMatch, $server, $url ) {
|
|
|
|
$this->assertEquals( $shouldMatch, ParserOutput::isLinkInternal( $server, $url ) );
|
|
}
|
|
|
|
public function testExtensionData() {
|
|
$po = new ParserOutput();
|
|
|
|
$po->setExtensionData( "one", "Foo" );
|
|
|
|
$this->assertEquals( "Foo", $po->getExtensionData( "one" ) );
|
|
$this->assertNull( $po->getExtensionData( "spam" ) );
|
|
|
|
$po->setExtensionData( "two", "Bar" );
|
|
$this->assertEquals( "Foo", $po->getExtensionData( "one" ) );
|
|
$this->assertEquals( "Bar", $po->getExtensionData( "two" ) );
|
|
|
|
$po->setExtensionData( "one", null );
|
|
$this->assertNull( $po->getExtensionData( "one" ) );
|
|
$this->assertEquals( "Bar", $po->getExtensionData( "two" ) );
|
|
}
|
|
}
|