mirror of
				https://github.com/ezyang/htmlpurifier.git
				synced 2025-10-25 18:46:31 +02:00 
			
		
		
		
	- Buggy treatment of end tags of elements that have required attributes fixed (does not manifest on default tag-set) - Spurious internal content reorganization error suppressed . Error unit tests can now specify the expectation of no errors. Future iterations of the harness will be extremely strict about what errors are allowed git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1424 48356398-32a2-884e-a903-53898d9a118a
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| require_once 'HTMLPurifier/StrategyHarness.php';
 | |
| require_once 'HTMLPurifier/Strategy/RemoveForeignElements.php';
 | |
| 
 | |
| class HTMLPurifier_Strategy_RemoveForeignElementsTest extends HTMLPurifier_StrategyHarness
 | |
| {
 | |
|     
 | |
|     function setUp() {
 | |
|         parent::setUp();
 | |
|         $this->obj = new HTMLPurifier_Strategy_RemoveForeignElements();
 | |
|     }
 | |
|     
 | |
|     function testBlankInput() {
 | |
|         $this->assertResult('');
 | |
|     }
 | |
|     
 | |
|     function testPreserveRecognizedElements() {
 | |
|         $this->assertResult('This is <b>bold text</b>.');
 | |
|     }
 | |
|     
 | |
|     function testRemoveForeignElements() {
 | |
|         $this->assertResult(
 | |
|             '<asdf>Bling</asdf><d href="bang">Bong</d><foobar />',
 | |
|             'BlingBong'
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testRemoveScriptAndContents() {
 | |
|         $this->assertResult(
 | |
|             '<script>alert();</script>',
 | |
|             ''
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testRemoveStyleAndContents() {
 | |
|         $this->assertResult(
 | |
|             '<style>.foo {blink;}</style>',
 | |
|             ''
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testRemoveOnlyScriptTagsLegacy() {
 | |
|         $this->config->set('Core', 'RemoveScriptContents', false);
 | |
|         $this->assertResult(
 | |
|             '<script>alert();</script>',
 | |
|             'alert();'
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testRemoveOnlyScriptTags() {
 | |
|         $this->config->set('Core', 'HiddenElements', array());
 | |
|         $this->assertResult(
 | |
|             '<script>alert();</script>',
 | |
|             'alert();'
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testRemoveInvalidImg() {
 | |
|         $this->assertResult('<img />', '');
 | |
|     }
 | |
|     
 | |
|     function testPreserveValidImg() {
 | |
|         $this->assertResult('<img src="foobar.gif" alt="foobar.gif" />');
 | |
|     }
 | |
|     
 | |
|     function testPreserveInvalidImgWhenRemovalIsDisabled() {
 | |
|         $this->config->set('Core', 'RemoveInvalidImg', false);
 | |
|         $this->assertResult('<img />');
 | |
|     }
 | |
|     
 | |
|     function testTextifyCommentedScriptContents() {
 | |
|         $this->config->set('HTML', 'Trusted', true);
 | |
|         $this->config->set('Output', 'CommentScriptContents', false); // simplify output
 | |
|         $this->assertResult(
 | |
| '<script type="text/javascript"><!--
 | |
| alert(<b>bold</b>);
 | |
| // --></script>',
 | |
| '<script type="text/javascript">
 | |
| alert(<b>bold</b>);
 | |
| // </script>'
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testRequiredAttributesTestNotPerformedOnEndTag() {
 | |
|         $this->config->set('HTML', 'DefinitionID',
 | |
|             'HTMLPurifier_Strategy_RemoveForeignElementsTest'.
 | |
|             '->testRequiredAttributesTestNotPerformedOnEndTag');
 | |
|         $def =& $this->config->getHTMLDefinition(true);
 | |
|         $def->addElement('f', 'Block', 'Optional: #PCDATA', false, array('req*' => 'Text'));
 | |
|         $this->assertResult('<f req="text">Foo</f> Bar');
 | |
|     }
 | |
|     
 | |
| }
 | |
| 
 |