~~~', 'hello \'\'this\'\' is ~~~', ), ); } /** * @dataProvider providePreSaveTransform * @covers Parser::preSaveTransform */ public function testPreSaveTransform( $text, $expected ) { global $wgParser; $title = Title::newFromText( str_replace( '::', '__', __METHOD__ ) ); $user = new User(); $user->setName( "127.0.0.1" ); $popts = ParserOptions::newFromUser( $user ); $text = $wgParser->preSaveTransform( $text, $title, $user, $popts ); $this->assertEquals( $expected, $text ); } public static function provideStripOuterParagraph() { // This mimics the most common use case (stripping paragraphs generated by the parser). $message = new RawMessage( "Message text." ); return array( array( "

Text.

", "Text.", ), array( "

Text.

", "

Text.

", ), array( "

Text.\n

\n", "Text.", ), array( "

Text.

More text.

", "

Text.

More text.

", ), array( $message->parse(), "Message text.", ), ); } /** * @dataProvider provideStripOuterParagraph * @covers Parser::stripOuterParagraph */ public function testStripOuterParagraph( $text, $expected ) { $this->assertEquals( $expected, Parser::stripOuterParagraph( $text ) ); } /** * @expectedException MWException * @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->parse( 'baz', $title, $po ); } public function helperParserFunc( $input, $args, $parser ) { $title = Title::newFromText( 'foo' ); $po = new ParserOptions; $parser->parse( $input, $title, $po ); return 'bar'; } /** * @covers Parser::callParserFunction */ public function testCallParserFunction() { global $wgParser; // Normal parses test passing PPNodes. Test passing an array. $title = Title::newFromText( str_replace( '::', '__', __METHOD__ ) ); $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' ) ); $ret['text'] = $wgParser->mStripState->unstripBoth( $ret['text'] ); $this->assertSame( array( 'found' => true, 'text' => '
foo
', ), $ret, 'callParserFunction works for {{#tag:pre|foo|style=margin-left: 1.6em}}' ); } /** * @covers Parser::parse * @covers ParserOutput::getSections */ public function testGetSections() { global $wgParser; $title = Title::newFromText( str_replace( '::', '__', __METHOD__ ) ); $out = $wgParser->parse( "==foo==\n

bar

\n==baz==\n", $title, new ParserOptions() ); $this->assertSame( array( array( 'toclevel' => 1, 'level' => '2', 'line' => 'foo', 'number' => '1', 'index' => '1', 'fromtitle' => $title->getPrefixedDBkey(), 'byteoffset' => 0, 'anchor' => 'foo', ), array( 'toclevel' => 1, 'level' => '2', 'line' => 'bar', 'number' => '2', 'index' => '', 'fromtitle' => false, 'byteoffset' => null, 'anchor' => 'bar', ), array( 'toclevel' => 1, 'level' => '2', 'line' => 'baz', 'number' => '3', 'index' => '2', 'fromtitle' => $title->getPrefixedDBkey(), 'byteoffset' => 21, 'anchor' => 'baz', ), ), $out->getSections(), 'getSections() with proper value when

is used' ); } /** * @dataProvider provideNormalizeLinkUrl * @covers Parser::normalizeLinkUrl * @covers Parser::normalizeUrlComponent */ public function testNormalizeLinkUrl( $explanation, $url, $expected ) { $this->assertEquals( $expected, Parser::normalizeLinkUrl( $url ), $explanation ); } public static function provideNormalizeLinkUrl() { return array( array( '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(), // replaceSection(), getPreloadText() }