mirror of
				https://github.com/ezyang/htmlpurifier.git
				synced 2025-10-25 02:26:32 +02:00 
			
		
		
		
	git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/branches/php4@1721 48356398-32a2-884e-a903-53898d9a118a
		
			
				
	
	
		
			112 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| require_once 'HTMLPurifier/AttrDefHarness.php';
 | |
| require_once 'HTMLPurifier/AttrDef/URI.php';
 | |
| require_once 'HTMLPurifier/URIParser.php';
 | |
| 
 | |
| /**
 | |
|  * @todo Aim for complete code coverage with mocks
 | |
|  */
 | |
| class HTMLPurifier_AttrDef_URITest extends HTMLPurifier_AttrDefHarness
 | |
| {
 | |
|     
 | |
|     function setUp() {
 | |
|         $this->def = new HTMLPurifier_AttrDef_URI();
 | |
|         parent::setUp();
 | |
|     }
 | |
|     
 | |
|     function testIntegration() {
 | |
|         $this->assertDef('http://www.google.com/');
 | |
|         $this->assertDef('http:', '');
 | |
|         $this->assertDef('http:/foo', '/foo');
 | |
|         $this->assertDef('javascript:bad_stuff();', false);
 | |
|         $this->assertDef('ftp://www.example.com/');
 | |
|         $this->assertDef('news:rec.alt');
 | |
|         $this->assertDef('nntp://news.example.com/324234');
 | |
|         $this->assertDef('mailto:bob@example.com');
 | |
|     }
 | |
|     
 | |
|     function testIntegrationWithPercentEncoder() {
 | |
|         $this->assertDef(
 | |
|             'http://www.example.com/%56%fc%GJ%5%FC',
 | |
|             'http://www.example.com/V%FC%25GJ%255%FC'
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testPercentEncoding() {
 | |
|         $this->assertDef(
 | |
|             'http:colon:mercenary',
 | |
|             'colon%3Amercenary'
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testPercentEncodingPreserve() {
 | |
|         $this->assertDef(
 | |
|             'http://www.example.com/abcABC123-_.!~*()\''
 | |
|         );
 | |
|     }
 | |
|     
 | |
|     function testEmbeds() {
 | |
|         $this->def = new HTMLPurifier_AttrDef_URI(true);
 | |
|         $this->assertDef('http://sub.example.com/alas?foo=asd');
 | |
|         $this->assertDef('mailto:foo@example.com', false);
 | |
|     }
 | |
|     
 | |
|     function testConfigMunge() {
 | |
|         $this->config->set('URI', 'Munge', 'http://www.google.com/url?q=%s');
 | |
|         $this->assertDef(
 | |
|             'http://www.example.com/',
 | |
|             'http://www.google.com/url?q=http%3A%2F%2Fwww.example.com%2F'
 | |
|         );
 | |
|         $this->assertDef('index.html');
 | |
|         $this->assertDef('javascript:foobar();', false);
 | |
|     }
 | |
|     
 | |
|     function testDefaultSchemeRemovedInBlank() {
 | |
|         $this->assertDef('http:', '');
 | |
|     }
 | |
|     
 | |
|     function testDefaultSchemeRemovedInRelativeURI() {
 | |
|         $this->assertDef('http:/foo/bar', '/foo/bar');
 | |
|     }
 | |
|     
 | |
|     function testDefaultSchemeNotRemovedInAbsoluteURI() {
 | |
|         $this->assertDef('http://example.com/foo/bar');
 | |
|     }
 | |
|     
 | |
|     function testAltSchemeNotRemoved() {
 | |
|         $this->assertDef('mailto:this-looks-like-a-path@example.com');
 | |
|     }
 | |
|     
 | |
|     function testURIDefinitionValidation() {
 | |
|         $parser = new HTMLPurifier_URIParser();
 | |
|         $uri = $parser->parse('http://example.com');
 | |
|         $this->config->set('URI', 'DefinitionID', 'HTMLPurifier_AttrDef_URITest->testURIDefinitionValidation');
 | |
|         $uri_def =& $this->config->getDefinition('URI');
 | |
|         // overload with mock
 | |
|         generate_mock_once('HTMLPurifier_URIDefinition');
 | |
|         $uri_def = new HTMLPurifier_URIDefinitionMock();
 | |
|         $uri_def->expectOnce('filter', array($uri, '*', '*'));
 | |
|         $uri_def->setReturnValue('filter', true, array($uri, '*', '*'));
 | |
|         $uri_def->setup = true;
 | |
|         $this->assertDef('http://example.com');
 | |
|     }
 | |
|     
 | |
|     /*
 | |
|     function test_validate_configWhitelist() {
 | |
|         
 | |
|         $this->config->set('URI', 'HostPolicy', 'DenyAll');
 | |
|         $this->config->set('URI', 'HostWhitelist', array(null, 'google.com'));
 | |
|         
 | |
|         $this->assertDef('http://example.com/fo/google.com', false);
 | |
|         $this->assertDef('server.txt');
 | |
|         $this->assertDef('ftp://www.google.com/?t=a');
 | |
|         $this->assertDef('http://google.com.tricky.spamsite.net', false);
 | |
|         
 | |
|     }
 | |
|     */
 | |
|     
 | |
| }
 | |
| 
 | |
| 
 |