mirror of
				https://github.com/ezyang/htmlpurifier.git
				synced 2025-10-26 02:56:47 +02:00 
			
		
		
		
	git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1332 48356398-32a2-884e-a903-53898d9a118a
		
			
				
	
	
		
			226 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			226 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| require_once 'HTMLPurifier/Generator.php';
 | |
| require_once 'HTMLPurifier/EntityLookup.php';
 | |
| 
 | |
| require_once 'HTMLPurifier/ComplexHarness.php';
 | |
| 
 | |
| class HTMLPurifier_GeneratorTest extends HTMLPurifier_ComplexHarness
 | |
| {
 | |
|     
 | |
|     var $gen;
 | |
|     var $_entity_lookup;
 | |
|     
 | |
|     function HTMLPurifier_GeneratorTest() {
 | |
|         $this->HTMLPurifier_Harness();
 | |
|         $this->gen = new HTMLPurifier_Generator();
 | |
|         $this->_entity_lookup = HTMLPurifier_EntityLookup::instance();
 | |
|     }
 | |
|     
 | |
|     function setUp() {
 | |
|         $this->obj       = new HTMLPurifier_Generator();
 | |
|         $this->func      = null;
 | |
|         $this->to_tokens = false;
 | |
|         $this->to_html   = false;
 | |
|     }
 | |
|     
 | |
|     function test_generateFromToken() {
 | |
|         
 | |
|         $inputs = $expect = array();
 | |
|         
 | |
|         $inputs[0] = new HTMLPurifier_Token_Text('Foobar.<>');
 | |
|         $expect[0] = 'Foobar.<>';
 | |
|         
 | |
|         $inputs[1] = new HTMLPurifier_Token_Start('a',
 | |
|                             array('href' => 'dyn?a=foo&b=bar')
 | |
|                          );
 | |
|         $expect[1] = '<a href="dyn?a=foo&b=bar">';
 | |
|         
 | |
|         $inputs[2] = new HTMLPurifier_Token_End('b');
 | |
|         $expect[2] = '</b>';
 | |
|         
 | |
|         $inputs[3] = new HTMLPurifier_Token_Empty('br',
 | |
|                             array('style' => 'font-family:"Courier New";')
 | |
|                          );
 | |
|         $expect[3] = '<br style="font-family:"Courier New";" />';
 | |
|         
 | |
|         $inputs[4] = new HTMLPurifier_Token_Start('asdf');
 | |
|         $expect[4] = '<asdf>';
 | |
|         
 | |
|         $inputs[5] = new HTMLPurifier_Token_Empty('br');
 | |
|         $expect[5] = '<br />';
 | |
|         
 | |
|         // test fault tolerance
 | |
|         $inputs[6] = null;
 | |
|         $expect[6] = '';
 | |
|         
 | |
|         // don't convert non-special characters
 | |
|         $theta_char = $this->_entity_lookup->table['theta'];
 | |
|         $inputs[7] = new HTMLPurifier_Token_Text($theta_char);
 | |
|         $expect[7] = $theta_char;
 | |
|         
 | |
|         foreach ($inputs as $i => $input) {
 | |
|             $result = $this->obj->generateFromToken($input);
 | |
|             $this->assertIdentical($result, $expect[$i]);
 | |
|             paintIf($result, $result != $expect[$i]);
 | |
|         }
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function test_generateAttributes() {
 | |
|         
 | |
|         $inputs = $expect = array();
 | |
|         
 | |
|         $inputs[0] = array();
 | |
|         $expect[0] = '';
 | |
|         
 | |
|         $inputs[1] = array('href' => 'dyn?a=foo&b=bar');
 | |
|         $expect[1] = 'href="dyn?a=foo&b=bar"';
 | |
|         
 | |
|         $inputs[2] = array('style' => 'font-family:"Courier New";');
 | |
|         $expect[2] = 'style="font-family:"Courier New";"';
 | |
|         
 | |
|         $inputs[3] = array('src' => 'picture.jpg', 'alt' => 'Short & interesting');
 | |
|         $expect[3] = 'src="picture.jpg" alt="Short & interesting"';
 | |
|         
 | |
|         // don't escape nonspecial characters
 | |
|         $theta_char = $this->_entity_lookup->table['theta'];
 | |
|         $inputs[4] = array('title' => 'Theta is ' . $theta_char);
 | |
|         $expect[4] = 'title="Theta is ' . $theta_char . '"';
 | |
|         
 | |
|         foreach ($inputs as $i => $input) {
 | |
|             $result = $this->obj->generateAttributes($input, 'irrelevant');
 | |
|             $this->assertIdentical($result, $expect[$i]);
 | |
|             paintIf($result, $result != $expect[$i]);
 | |
|         }
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function test_generateAttributes_minimized() {
 | |
|         $gen = new HTMLPurifier_Generator();
 | |
|         $context = new HTMLPurifier_Context();
 | |
|         $gen->generateFromTokens(array(), HTMLPurifier_Config::create(array('HTML.Doctype' => 'HTML 4.01 Transitional')), $context);
 | |
|         $result = $gen->generateAttributes(array('compact' => 'compact'), 'menu');
 | |
|         $this->assertIdentical($result, 'compact');
 | |
|     }
 | |
|     
 | |
|     function test_generateFromTokens() {
 | |
|         
 | |
|         $this->func = 'generateFromTokens';
 | |
|         
 | |
|         $this->assertResult(
 | |
|             array(
 | |
|                 new HTMLPurifier_Token_Start('b'),
 | |
|                 new HTMLPurifier_Token_Text('Foobar!'),
 | |
|                 new HTMLPurifier_Token_End('b')
 | |
|             ),
 | |
|             '<b>Foobar!</b>'
 | |
|         );
 | |
|         
 | |
|         $this->assertResult(array(), '');
 | |
|         
 | |
|     }
 | |
|     
 | |
|     var $config;
 | |
|     function assertGeneration($tokens, $expect) {
 | |
|         $context = new HTMLPurifier_Context();
 | |
|         $result = $this->gen->generateFromTokens(
 | |
|           $tokens, $this->config, $context);
 | |
|         // normalized newlines, this probably should be put somewhere else
 | |
|         $result = str_replace("\r\n", "\n", $result);
 | |
|         $result = str_replace("\r", "\n", $result);
 | |
|         $this->assertIdentical($expect, $result);
 | |
|     }
 | |
|     
 | |
|     function test_generateFromTokens_Scripting() {
 | |
|         $this->config = HTMLPurifier_Config::createDefault();
 | |
|         
 | |
|         $this->assertGeneration(
 | |
|             array(
 | |
|                 new HTMLPurifier_Token_Start('script'),
 | |
|                 new HTMLPurifier_Token_Text('alert(3 < 5);'),
 | |
|                 new HTMLPurifier_Token_End('script')
 | |
|             ),
 | |
|             "<script><!--//--><![CDATA[//><!--\nalert(3 < 5);\n//--><!]]></script>"
 | |
|         );
 | |
|         
 | |
|         // if missing close tag, don't do anything
 | |
|         $this->assertGeneration(
 | |
|             array(
 | |
|                 new HTMLPurifier_Token_Start('script'),
 | |
|                 new HTMLPurifier_Token_Text('alert(3 < 5);'),
 | |
|             ),
 | |
|             "<script>alert(3 < 5);"
 | |
|         );
 | |
|         
 | |
|         // if two script blocks, don't do anything
 | |
|         $this->assertGeneration(
 | |
|             array(
 | |
|                 new HTMLPurifier_Token_Start('script'),
 | |
|                 new HTMLPurifier_Token_Text('alert(3 < 5);'),
 | |
|                 new HTMLPurifier_Token_Text('foo();'),
 | |
|                 new HTMLPurifier_Token_End('script')
 | |
|             ),
 | |
|             "<script>alert(3 < 5);foo();</script>"
 | |
|         );
 | |
|         
 | |
|         
 | |
|         
 | |
|         $this->config = HTMLPurifier_Config::createDefault();
 | |
|         $this->config->set('Core', 'CommentScriptContents', false);
 | |
|         
 | |
|         $this->assertGeneration(
 | |
|             array(
 | |
|                 new HTMLPurifier_Token_Start('script'),
 | |
|                 new HTMLPurifier_Token_Text('alert(3 < 5);'),
 | |
|                 new HTMLPurifier_Token_End('script')
 | |
|             ),
 | |
|             "<script>alert(3 < 5);</script>"
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function test_generateFromTokens_XHTMLoff() {
 | |
|         $this->config = HTMLPurifier_Config::createDefault();
 | |
|         $this->config->set('Core', 'XHTML', false);
 | |
|         
 | |
|         // omit trailing slash
 | |
|         $this->assertGeneration(
 | |
|             array( new HTMLPurifier_Token_Empty('br') ),
 | |
|             '<br>'
 | |
|         );
 | |
|         
 | |
|         // there should be a test for attribute minimization, but it is
 | |
|         // impossible for something like that to happen due to our current
 | |
|         // definitions! fix it later
 | |
|         
 | |
|         // namespaced attributes must be dropped
 | |
|         $this->assertGeneration(
 | |
|             array( new HTMLPurifier_Token_Start('p', array('xml:lang'=>'fr')) ),
 | |
|             '<p>'
 | |
|         );
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function test_generateFromTokens_TidyFormat() {
 | |
|         // abort test if tidy isn't loaded
 | |
|         if (!extension_loaded('tidy')) return;
 | |
|         
 | |
|         $this->config = HTMLPurifier_Config::createDefault();
 | |
|         $this->config->set('Core', 'TidyFormat', true);
 | |
|         $this->config->set('Output', 'Newline', "\n");
 | |
|         
 | |
|         // nice wrapping please
 | |
|         $this->assertGeneration(
 | |
|             array(
 | |
|                 new HTMLPurifier_Token_Start('div'),
 | |
|                 new HTMLPurifier_Token_Text('Text'),
 | |
|                 new HTMLPurifier_Token_End('div')
 | |
|             ),
 | |
|             "<div>\n  Text\n</div>\n"
 | |
|         );
 | |
|         
 | |
|     }
 | |
|     
 | |
| }
 | |
| 
 |