2009-10-11 00:06:57 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2009-10-11 00:06:57 +00:00
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class ShortcodeParserTest extends SapphireTest {
|
|
|
|
|
|
|
|
protected $arguments, $contents, $tagName, $parser;
|
|
|
|
|
|
|
|
public function setUp() {
|
|
|
|
ShortcodeParser::get('test')->register('test_shortcode', array($this, 'shortcodeSaver'));
|
|
|
|
$this->parser = ShortcodeParser::get('test');
|
|
|
|
|
|
|
|
parent::setUp();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests that valid short codes that have not been registered are not replaced.
|
|
|
|
*/
|
|
|
|
public function testNotRegisteredShortcode() {
|
2013-02-14 15:11:10 +13:00
|
|
|
ShortcodeParser::$error_behavior = ShortcodeParser::STRIP;
|
2013-02-22 11:34:15 +13:00
|
|
|
|
2013-02-14 15:11:10 +13:00
|
|
|
$this->assertEquals(
|
|
|
|
'',
|
|
|
|
$this->parser->parse('[not_shortcode]')
|
|
|
|
);
|
|
|
|
|
2013-02-22 11:34:15 +13:00
|
|
|
$this->assertEquals(
|
|
|
|
'<img class="">',
|
|
|
|
$this->parser->parse('<img class="[not_shortcode]">')
|
|
|
|
);
|
|
|
|
|
2013-02-14 15:11:10 +13:00
|
|
|
ShortcodeParser::$error_behavior = ShortcodeParser::WARN;
|
2013-02-22 11:34:15 +13:00
|
|
|
|
2013-02-14 15:11:10 +13:00
|
|
|
$this->assertEquals(
|
|
|
|
'<strong class="warning">[not_shortcode]</strong>',
|
|
|
|
$this->parser->parse('[not_shortcode]')
|
|
|
|
);
|
|
|
|
|
|
|
|
ShortcodeParser::$error_behavior = ShortcodeParser::LEAVE;
|
2013-02-22 11:34:15 +13:00
|
|
|
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('[not_shortcode]',
|
|
|
|
$this->parser->parse('[not_shortcode]'));
|
|
|
|
$this->assertEquals('[not_shortcode /]',
|
|
|
|
$this->parser->parse('[not_shortcode /]'));
|
|
|
|
$this->assertEquals('[not_shortcode,foo="bar"]',
|
|
|
|
$this->parser->parse('[not_shortcode,foo="bar"]'));
|
|
|
|
$this->assertEquals('[not_shortcode]a[/not_shortcode]',
|
|
|
|
$this->parser->parse('[not_shortcode]a[/not_shortcode]'));
|
2013-02-14 15:11:10 +13:00
|
|
|
$this->assertEquals('[/not_shortcode]',
|
|
|
|
$this->parser->parse('[/not_shortcode]'));
|
2013-02-22 11:34:15 +13:00
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'<img class="[not_shortcode]">',
|
|
|
|
$this->parser->parse('<img class="[not_shortcode]">')
|
|
|
|
);
|
2009-10-11 00:06:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSimpleTag() {
|
2013-02-14 15:11:10 +13:00
|
|
|
$tests = array(
|
|
|
|
'[test_shortcode]',
|
|
|
|
'[test_shortcode ]', '[test_shortcode,]', '[test_shortcode, ]'.
|
|
|
|
'[test_shortcode/]', '[test_shortcode /]', '[test_shortcode,/]', '[test_shortcode, /]'
|
|
|
|
);
|
2009-10-11 00:06:57 +00:00
|
|
|
|
|
|
|
foreach($tests as $test) {
|
|
|
|
$this->parser->parse($test);
|
|
|
|
|
|
|
|
$this->assertEquals(array(), $this->arguments, $test);
|
|
|
|
$this->assertEquals('', $this->contents, $test);
|
|
|
|
$this->assertEquals('test_shortcode', $this->tagName, $test);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testOneArgument() {
|
|
|
|
$tests = array (
|
2013-02-14 15:11:10 +13:00
|
|
|
'[test_shortcode foo="bar"]', '[test_shortcode,foo="bar"]',
|
|
|
|
"[test_shortcode foo='bar']", "[test_shortcode,foo='bar']",
|
|
|
|
'[test_shortcode foo = "bar" /]', '[test_shortcode, foo = "bar" /]'
|
2009-10-11 00:06:57 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
foreach($tests as $test) {
|
|
|
|
$this->parser->parse($test);
|
|
|
|
|
|
|
|
$this->assertEquals(array('foo' => 'bar'), $this->arguments, $test);
|
|
|
|
$this->assertEquals('', $this->contents, $test);
|
|
|
|
$this->assertEquals('test_shortcode', $this->tagName, $test);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testMultipleArguments() {
|
2013-02-14 15:11:10 +13:00
|
|
|
$this->parser->parse('[test_shortcode foo = "bar",bar=\'foo\', baz="buz"]');
|
2009-10-11 00:06:57 +00:00
|
|
|
|
|
|
|
$this->assertEquals(array('foo' => 'bar', 'bar' => 'foo', 'baz' => 'buz'), $this->arguments);
|
|
|
|
$this->assertEquals('', $this->contents);
|
|
|
|
$this->assertEquals('test_shortcode', $this->tagName);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testEnclosing() {
|
|
|
|
$this->parser->parse('[test_shortcode]foo[/test_shortcode]');
|
|
|
|
|
|
|
|
$this->assertEquals(array(), $this->arguments);
|
|
|
|
$this->assertEquals('foo', $this->contents);
|
|
|
|
$this->assertEquals('test_shortcode', $this->tagName);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testEnclosingWithArguments() {
|
2012-03-09 15:00:03 +13:00
|
|
|
$this->parser->parse('[test_shortcode,foo = "bar",bar=\'foo\',baz="buz"]foo[/test_shortcode]');
|
2009-10-11 00:06:57 +00:00
|
|
|
|
|
|
|
$this->assertEquals(array('foo' => 'bar', 'bar' => 'foo', 'baz' => 'buz'), $this->arguments);
|
|
|
|
$this->assertEquals('foo', $this->contents);
|
|
|
|
$this->assertEquals('test_shortcode', $this->tagName);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testShortcodeEscaping() {
|
2013-02-22 10:30:51 +13:00
|
|
|
$this->assertEquals(
|
|
|
|
'[test_shortcode]',
|
|
|
|
$this->parser->parse('[[test_shortcode]]')
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'[test_shortcode /]',
|
|
|
|
$this->parser->parse('[[test_shortcode /]]')
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'[test_shortcode]content[/test_shortcode]',
|
|
|
|
$this->parser->parse('[[test_shortcode]content[/test_shortcode]]'
|
|
|
|
));
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'[test_shortcode]content',
|
|
|
|
$this->parser->parse('[[test_shortcode]][test_shortcode]content[/test_shortcode]')
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'[test_shortcode]content[/test_shortcode]content2',
|
|
|
|
$this->parser->parse('[[test_shortcode]content[/test_shortcode]][test_shortcode]content2[/test_shortcode]'
|
|
|
|
));
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'[[Doesnt strip double [ character if not a shortcode',
|
|
|
|
$this->parser->parse('[[Doesnt strip double [ character if not a [test_shortcode]shortcode[/test_shortcode]'
|
|
|
|
));
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
'[[Doesnt shortcode get confused by double ]] characters',
|
|
|
|
$this->parser->parse('[[Doesnt [test_shortcode]shortcode[/test_shortcode] get confused by double ]] characters'
|
|
|
|
));
|
2009-10-11 00:06:57 +00:00
|
|
|
}
|
2013-02-14 15:11:10 +13:00
|
|
|
|
2009-10-11 00:06:57 +00:00
|
|
|
public function testUnquotedArguments() {
|
2012-03-09 14:25:42 +13:00
|
|
|
$this->assertEquals('', $this->parser->parse('[test_shortcode,foo=bar,baz = buz]'));
|
2009-10-11 00:06:57 +00:00
|
|
|
$this->assertEquals(array('foo' => 'bar', 'baz' => 'buz'), $this->arguments);
|
|
|
|
}
|
|
|
|
|
2012-03-09 15:00:03 +13:00
|
|
|
public function testSpacesForDelimiter() {
|
|
|
|
$this->assertEquals('', $this->parser->parse('[test_shortcode foo=bar baz = buz]'));
|
|
|
|
$this->assertEquals(array('foo' => 'bar', 'baz' => 'buz'), $this->arguments);
|
|
|
|
}
|
|
|
|
|
2009-10-11 00:06:57 +00:00
|
|
|
public function testSelfClosingTag() {
|
|
|
|
$this->assertEquals (
|
|
|
|
'morecontent',
|
2012-03-09 14:25:42 +13:00
|
|
|
$this->parser->parse('[test_shortcode,id="1"/]more[test_shortcode,id="2"]content[/test_shortcode]'),
|
2009-10-11 00:06:57 +00:00
|
|
|
'Assert that self-closing tags are respected during parsing.'
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(2, $this->arguments['id']);
|
|
|
|
}
|
2012-05-23 18:18:06 +12:00
|
|
|
|
|
|
|
public function testConsecutiveTags() {
|
|
|
|
$this->assertEquals('', $this->parser->parse('[test_shortcode][test_shortcode]'));
|
|
|
|
}
|
2009-10-11 00:06:57 +00:00
|
|
|
|
2013-02-14 15:11:10 +13:00
|
|
|
protected function assertEqualsIgnoringWhitespace($a, $b, $message = null) {
|
|
|
|
$this->assertEquals(preg_replace('/\s+/', '', $a), preg_replace('/\s+/', '', $b), $message);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testtExtract() {
|
|
|
|
// Left extracts to before the current block
|
|
|
|
$this->assertEqualsIgnoringWhitespace(
|
|
|
|
'Code<div>FooBar</div>',
|
|
|
|
$this->parser->parse('<div>Foo[test_shortcode class=left]Code[/test_shortcode]Bar</div>')
|
|
|
|
);
|
|
|
|
|
|
|
|
// Even if the immediate parent isn't a the current block
|
|
|
|
$this->assertEqualsIgnoringWhitespace(
|
|
|
|
'Code<div>Foo<b>BarBaz</b>Qux</div>',
|
|
|
|
$this->parser->parse('<div>Foo<b>Bar[test_shortcode class=left]Code[/test_shortcode]Baz</b>Qux</div>')
|
|
|
|
);
|
|
|
|
|
|
|
|
// Center splits the current block
|
|
|
|
$this->assertEqualsIgnoringWhitespace(
|
|
|
|
'<div>Foo</div>Code<div>Bar</div>',
|
|
|
|
$this->parser->parse('<div>Foo[test_shortcode class=center]Code[/test_shortcode]Bar</div>')
|
|
|
|
);
|
|
|
|
|
|
|
|
// Even if the immediate parent isn't a the current block
|
|
|
|
$this->assertEqualsIgnoringWhitespace(
|
|
|
|
'<div>Foo<b>Bar</b></div>Code<div><b>Baz</b>Qux</div>',
|
|
|
|
$this->parser->parse('<div>Foo<b>Bar[test_shortcode class=center]Code[/test_shortcode]Baz</b>Qux</div>')
|
|
|
|
);
|
|
|
|
|
|
|
|
// No class means don't extract
|
|
|
|
$this->assertEqualsIgnoringWhitespace(
|
|
|
|
'<div>FooCodeBar</div>',
|
|
|
|
$this->parser->parse('<div>Foo[test_shortcode]Code[/test_shortcode]Bar</div>')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2009-10-11 00:06:57 +00:00
|
|
|
// -----------------------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stores the result of a shortcode parse in object properties for easy testing access.
|
|
|
|
*/
|
|
|
|
public function shortcodeSaver($arguments, $content = null, $parser, $tagName = null) {
|
|
|
|
$this->arguments = $arguments;
|
|
|
|
$this->contents = $content;
|
|
|
|
$this->tagName = $tagName;
|
|
|
|
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2012-03-09 14:25:42 +13:00
|
|
|
}
|