<?php
+/**
+ * @group Database
+ */
+
class ParserMethodsTest extends MediaWikiLangTestCase {
public static function providePreSaveTransform() {
- return array(
- array( 'hello this is ~~~',
+ return [
+ [ 'hello this is ~~~',
"hello this is [[Special:Contributions/127.0.0.1|127.0.0.1]]",
- ),
- array( 'hello \'\'this\'\' is <nowiki>~~~</nowiki>',
+ ],
+ [ 'hello \'\'this\'\' is <nowiki>~~~</nowiki>',
'hello \'\'this\'\' is <nowiki>~~~</nowiki>',
- ),
- );
+ ],
+ ];
}
/**
// This mimics the most common use case (stripping paragraphs generated by the parser).
$message = new RawMessage( "Message text." );
- return array(
- array(
+ return [
+ [
"<p>Text.</p>",
"Text.",
- ),
- array(
+ ],
+ [
"<p class='foo'>Text.</p>",
"<p class='foo'>Text.</p>",
- ),
- array(
+ ],
+ [
"<p>Text.\n</p>\n",
"Text.",
- ),
- array(
+ ],
+ [
"<p>Text.</p><p>More text.</p>",
"<p>Text.</p><p>More text.</p>",
- ),
- array(
+ ],
+ [
$message->parse(),
"Message text.",
- ),
- );
+ ],
+ ];
}
/**
/**
* @expectedException MWException
- * @expectedExceptionMessage Parser state cleared while parsing. Did you call Parser::parse recursively?
+ * @expectedExceptionMessage Parser state cleared while parsing.
+ * Did you call Parser::parse recursively?
* @covers Parser::lock
*/
public function testRecursiveParse() {
global $wgParser;
$title = Title::newFromText( 'foo' );
$po = new ParserOptions;
- $wgParser->setHook( 'recursivecallparser', array( $this, 'helperParserFunc' ) );
+ $wgParser->setHook( 'recursivecallparser', [ $this, 'helperParserFunc' ] );
$wgParser->parse( '<recursivecallparser>baz</recursivecallparser>', $title, $po );
}
$wgParser->startExternalParse( $title, new ParserOptions(), Parser::OT_HTML );
$frame = $wgParser->getPreprocessor()->newFrame();
$ret = $wgParser->callParserFunction( $frame, '#tag',
- array( 'pre', 'foo', 'style' => 'margin-left: 1.6em' )
+ [ 'pre', 'foo', 'style' => 'margin-left: 1.6em' ]
);
$ret['text'] = $wgParser->mStripState->unstripBoth( $ret['text'] );
- $this->assertSame( array(
+ $this->assertSame( [
'found' => true,
'text' => '<pre style="margin-left: 1.6em">foo</pre>',
- ), $ret, 'callParserFunction works for {{#tag:pre|foo|style=margin-left: 1.6em}}' );
+ ], $ret, 'callParserFunction works for {{#tag:pre|foo|style=margin-left: 1.6em}}' );
}
/**
$title = Title::newFromText( str_replace( '::', '__', __METHOD__ ) );
$out = $wgParser->parse( "==foo==\n<h2>bar</h2>\n==baz==\n", $title, new ParserOptions() );
- $this->assertSame( array(
- array(
+ $this->assertSame( [
+ [
'toclevel' => 1,
'level' => '2',
'line' => 'foo',
'fromtitle' => $title->getPrefixedDBkey(),
'byteoffset' => 0,
'anchor' => 'foo',
- ),
- array(
+ ],
+ [
'toclevel' => 1,
'level' => '2',
'line' => 'bar',
'fromtitle' => false,
'byteoffset' => null,
'anchor' => 'bar',
- ),
- array(
+ ],
+ [
'toclevel' => 1,
'level' => '2',
'line' => 'baz',
'fromtitle' => $title->getPrefixedDBkey(),
'byteoffset' => 21,
'anchor' => 'baz',
- ),
- ), $out->getSections(), 'getSections() with proper value when <h2> is used' );
+ ],
+ ], $out->getSections(), 'getSections() with proper value when <h2> is used' );
}
/**
}
public static function provideNormalizeLinkUrl() {
- return array(
- array(
+ return [
+ [
'Escaping of unsafe characters',
'http://example.org/foo bar?param[]="value"¶m[]=valüe',
'http://example.org/foo%20bar?param%5B%5D=%22value%22¶m%5B%5D=val%C3%BCe',
- ),
- array(
+ ],
+ [
'Case normalization of percent-encoded characters',
'http://example.org/%ab%cD%Ef%FF',
'http://example.org/%AB%CD%EF%FF',
- ),
- array(
+ ],
+ [
'Unescaping of safe characters',
'http://example.org/%3C%66%6f%6F%3E?%3C%66%6f%6F%3E#%3C%66%6f%6F%3E',
'http://example.org/%3Cfoo%3E?%3Cfoo%3E#%3Cfoo%3E',
- ),
- array(
+ ],
+ [
'Context-sensitive replacement of sometimes-safe characters',
'http://example.org/%23%2F%3F%26%3D%2B%3B?%23%2F%3F%26%3D%2B%3B#%23%2F%3F%26%3D%2B%3B',
'http://example.org/%23%2F%3F&=+;?%23/?%26%3D%2B%3B#%23/?&=+;',
- ),
- );
+ ],
+ ];
}
// @todo Add tests for cleanSig() / cleanSigInSig(), getSection(),