mirror of
				https://github.com/ezyang/htmlpurifier.git
				synced 2025-10-25 10:36:59 +02:00 
			
		
		
		
	git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@615 48356398-32a2-884e-a903-53898d9a118a
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| require_once 'HTMLPurifier.php';
 | |
| 
 | |
| // integration test
 | |
| 
 | |
| class HTMLPurifier_Test extends UnitTestCase
 | |
| {
 | |
|     var $purifier;
 | |
|     
 | |
|     function setUp() {
 | |
|         $this->purifier = new HTMLPurifier();
 | |
|     }
 | |
|     
 | |
|     function assertPurification($input, $expect = null) {
 | |
|         if ($expect === null) $expect = $input;
 | |
|         $result = $this->purifier->purify($input);
 | |
|         $this->assertIdentical($expect, $result);
 | |
|     }
 | |
|     
 | |
|     function testNull() {
 | |
|         $this->assertPurification("Null byte\0", "Null byte");
 | |
|     }
 | |
|     
 | |
|     function testStrict() {
 | |
|         $config = HTMLPurifier_Config::createDefault();
 | |
|         $config->set('HTML', 'Strict', true);
 | |
|         $this->purifier = new HTMLPurifier( $config ); // verbose syntax
 | |
|         
 | |
|         $this->assertPurification(
 | |
|             '<u>Illegal underline</u>',
 | |
|             'Illegal underline'
 | |
|         );
 | |
|         
 | |
|         $this->assertPurification(
 | |
|             '<blockquote>Illegal contents</blockquote>',
 | |
|             '<blockquote><p>Illegal contents</p></blockquote>'
 | |
|         );
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function testDifferentAllowedElements() {
 | |
|         
 | |
|         $this->purifier = new HTMLPurifier(array(
 | |
|             'HTML.AllowedElements' => array('b', 'i', 'p', 'a'),
 | |
|             'HTML.AllowedAttributes' => array('a.href', '*.id')
 | |
|         ));
 | |
|         
 | |
|         $this->assertPurification(
 | |
|             '<p>Par.</p><p>Para<a href="http://google.com/">gr</a>aph</p>Text<b>Bol<i>d</i></b>'
 | |
|         );
 | |
|         
 | |
|         $this->assertPurification(
 | |
|             '<span>Not allowed</span><a class="mef" id="foobar">Foobar</a>',
 | |
|             'Not allowed<a>Foobar</a>' // no ID!!!
 | |
|         );
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function testDisableURI() {
 | |
|         
 | |
|         $this->purifier = new HTMLPurifier( array('Attr.DisableURI' => true) );
 | |
|         
 | |
|         $this->assertPurification(
 | |
|             '<img src="foobar"/>',
 | |
|             ''
 | |
|         );
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function test_purifyArray() {
 | |
|         
 | |
|         $this->purifier = new HTMLPurifier();
 | |
|         
 | |
|         $this->assertEqual(
 | |
|             $this->purifier->purifyArray(
 | |
|                 array('Good', '<b>Sketchy', 'foo' => '<script>bad</script>')
 | |
|             ),
 | |
|             array('Good', '<b>Sketchy</b>', 'foo' => 'bad')
 | |
|         );
 | |
|         
 | |
|         $this->assertIsA($this->purifier->context, 'array');
 | |
|         
 | |
|     }
 | |
|     
 | |
| }
 | |
| 
 | |
| ?>
 |