mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 21:21:32 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			116 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  *
 | |
|  * This file is part of the phpBB Forum Software package.
 | |
|  *
 | |
|  * @copyright (c) phpBB Limited <https://www.phpbb.com>
 | |
|  * @license GNU General Public License, version 2 (GPL-2.0)
 | |
|  *
 | |
|  * For full copyright and license information, please see
 | |
|  * the docs/CREDITS.txt file.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @group functional
 | |
|  */
 | |
| class phpbb_functional_acp_bbcodes_test extends phpbb_functional_test_case
 | |
| {
 | |
| 	public function test_htmlspecialchars()
 | |
| 	{
 | |
| 		$this->login();
 | |
| 		$this->admin_login();
 | |
| 
 | |
| 		// Create the BBCode
 | |
| 		$crawler = self::request('GET', 'adm/index.php?i=acp_bbcodes&sid=' . $this->sid . '&mode=bbcodes&action=add');
 | |
| 		$form = $crawler->selectButton('Submit')->form(array(
 | |
| 			'bbcode_match'		=> '[mod="{TEXT1}"]{TEXT2}[/mod]',
 | |
| 			'bbcode_tpl'		=> '<div>{TEXT1}</div><div>{TEXT2}</div>',
 | |
| 			'bbcode_font_icon'	=> 'user',
 | |
| 		));
 | |
| 		self::submit($form);
 | |
| 
 | |
| 		// Test it in the "new topic" preview
 | |
| 		$crawler = self::request('GET', 'posting.php?mode=post&f=2&sid=' . $this->sid);
 | |
| 		$form = $crawler->selectButton('Preview')->form(array(
 | |
| 			'subject' => 'subject',
 | |
| 			'message' => '[mod=a]b[/mod][mod="c"]d[/mod]'
 | |
| 		));
 | |
| 		$crawler = self::submit($form);
 | |
| 
 | |
| 		$html = $crawler->filter('#preview')->html();
 | |
| 		$this->assertStringContainsString('<div>a</div>', $html);
 | |
| 		$this->assertStringContainsString('<div>b</div>', $html);
 | |
| 		$this->assertStringContainsString('<div>c</div>', $html);
 | |
| 		$this->assertStringContainsString('<div>d</div>', $html);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* @dataProvider get_bbcode_error_tests
 | |
| 	*/
 | |
| 	public function test_bbcode_error($match, $tpl, $icon, $error)
 | |
| 	{
 | |
| 		$this->login();
 | |
| 		$this->admin_login();
 | |
| 
 | |
| 		$crawler = self::request('GET', 'adm/index.php?i=acp_bbcodes&sid=' . $this->sid . '&mode=bbcodes&action=add');
 | |
| 		$form = $crawler->selectButton('Submit')->form([
 | |
| 			'bbcode_match'		=> $match,
 | |
| 			'bbcode_tpl'		=> $tpl,
 | |
| 			'bbcode_font_icon'	=> $icon,
 | |
| 		]);
 | |
| 		$crawler = self::submit($form);
 | |
| 
 | |
| 		$text = $crawler->filter('.errorbox')->text();
 | |
| 		$this->assertStringContainsString($error, $text);
 | |
| 	}
 | |
| 
 | |
| 	public static function get_bbcode_error_tests()
 | |
| 	{
 | |
| 		return [
 | |
| 			[
 | |
| 				'XXX',
 | |
| 				'',
 | |
| 				'',
 | |
| 				'BBCode is constructed in an invalid form'
 | |
| 			],
 | |
| 			[
 | |
| 				'[x]{TEXT}[/x]',
 | |
| 				'<xsl:invalid',
 | |
| 				'',
 | |
| 				'template is invalid'
 | |
| 			],
 | |
| 			[
 | |
| 				'[x]{TEXT}[/x]',
 | |
| 				'<script>{TEXT}</script>',
 | |
| 				'',
 | |
| 				'unsafe'
 | |
| 			],
 | |
| 			'icon name too long' => [
 | |
| 				'[mod2="{TEXT1}"]{TEXT2}[/mod2]',
 | |
| 				'<div>{TEXT1}</div><div>{TEXT2}</div>',
 | |
| 				str_repeat('a', 65),
 | |
| 				'is too long',
 | |
| 			],
 | |
| 			'icon name invalid' => [
 | |
| 				'[mod2="{TEXT1}"]{TEXT2}[/mod2]',
 | |
| 				'<div>{TEXT1}</div><div>{TEXT2}</div>',
 | |
| 				'Not a valid icon name',
 | |
| 				'is invalid',
 | |
| 			],
 | |
| 			'icon name invalid double dash' => [
 | |
| 				'[mod2="{TEXT1}"]{TEXT2}[/mod2]',
 | |
| 				'<div>{TEXT1}</div><div>{TEXT2}</div>',
 | |
| 				'us--er',
 | |
| 				'is invalid',
 | |
| 			],
 | |
| 			'icon name invalid trailing dash' => [
 | |
| 				'[mod2="{TEXT1}"]{TEXT2}[/mod2]',
 | |
| 				'<div>{TEXT1}</div><div>{TEXT2}</div>',
 | |
| 				'user-',
 | |
| 				'is invalid',
 | |
| 			],
 | |
| 		];
 | |
| 	}
 | |
| }
 |