mirror of
				https://github.com/ezyang/htmlpurifier.git
				synced 2025-10-20 16:26:15 +02:00 
			
		
		
		
	- Elimination of ConfigDef and subclasses in favor of stdclass. Most property names stay the same - Added benchmark script for ConfigSchema - Types are internally handled as magic integers. Use HTMLPurifier_VarParser->getTypeName to convert to human readable form. HTMLPurifier_VarParser still accepts strings. - Parser in config schema only used for legacy interface git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1764 48356398-32a2-884e-a903-53898d9a118a
		
			
				
	
	
		
			111 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| class HTMLPurifier_ConfigSchemaTest extends HTMLPurifier_Harness
 | |
| {
 | |
|     
 | |
|     protected $schema;
 | |
|     
 | |
|     public function setup() {
 | |
|         $this->schema = new HTMLPurifier_ConfigSchema();
 | |
|     }
 | |
|     
 | |
|     function test_defineNamespace() {
 | |
|         $this->schema->addNamespace('http');
 | |
|         $this->assertIdentical($this->schema->info['http'], array());
 | |
|         $this->assertIdentical($this->schema->defaults['http'], array());
 | |
|     }
 | |
|     
 | |
|     function test_define() {
 | |
|         $this->schema->addNamespace('Car');
 | |
|         
 | |
|         $this->schema->add('Car', 'Seats', 5, 'int', false);
 | |
|         
 | |
|         $this->assertIdentical($this->schema->defaults['Car']['Seats'], 5);
 | |
|         $this->assertIdentical($this->schema->info['Car']['Seats']->type, HTMLPurifier_VarParser::INT);
 | |
|         
 | |
|         $this->schema->add('Car', 'Age', null, 'int', true);
 | |
|         
 | |
|         $this->assertIdentical($this->schema->defaults['Car']['Age'], null);
 | |
|         $this->assertIdentical($this->schema->info['Car']['Age']->type, HTMLPurifier_VarParser::INT);
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function test_defineAllowedValues() {
 | |
|         $this->schema->addNamespace('QuantumNumber', 'D');
 | |
|         $this->schema->add('QuantumNumber', 'Spin', 0.5, 'float', false);
 | |
|         $this->schema->add('QuantumNumber', 'Current', 's', 'string', false);
 | |
|         $this->schema->add('QuantumNumber', 'Difficulty', null, 'string', true);
 | |
|         
 | |
|         $this->schema->addAllowedValues( // okay, since default is null
 | |
|             'QuantumNumber', 'Difficulty', array('easy' => true, 'medium' => true, 'hard' => true)
 | |
|         );
 | |
|         
 | |
|         $this->assertIdentical($this->schema->defaults['QuantumNumber']['Difficulty'], null);
 | |
|         $this->assertIdentical($this->schema->info['QuantumNumber']['Difficulty']->type, HTMLPurifier_VarParser::STRING);
 | |
|         $this->assertIdentical($this->schema->info['QuantumNumber']['Difficulty']->allow_null, true);
 | |
|         $this->assertIdentical($this->schema->info['QuantumNumber']['Difficulty']->allowed, 
 | |
|             array(
 | |
|                 'easy' => true,
 | |
|                 'medium' => true,
 | |
|                 'hard' => true
 | |
|             )
 | |
|         );
 | |
|         
 | |
|     }
 | |
|     
 | |
|     function test_defineValueAliases() {
 | |
|         $this->schema->addNamespace('Abbrev', 'Stuff on abbreviations.');
 | |
|         $this->schema->add('Abbrev', 'HTH', 'Happy to Help', 'string', false);
 | |
|         $this->schema->addAllowedValues(
 | |
|             'Abbrev', 'HTH', array(
 | |
|                 'Happy to Help' => true,
 | |
|                 'Hope that Helps' => true,
 | |
|                 'HAIL THE HAND!' => true,
 | |
|             )
 | |
|         );
 | |
|         $this->schema->addValueAliases(
 | |
|             'Abbrev', 'HTH', array(
 | |
|                 'happy' => 'Happy to Help',
 | |
|                 'hope' => 'Hope that Helps'
 | |
|             )
 | |
|         );
 | |
|         $this->schema->addValueAliases( // delayed addition
 | |
|             'Abbrev', 'HTH', array(
 | |
|                 'hail' => 'HAIL THE HAND!'
 | |
|             )
 | |
|         );
 | |
|         
 | |
|         $this->assertIdentical($this->schema->defaults['Abbrev']['HTH'], 'Happy to Help');
 | |
|         $this->assertIdentical($this->schema->info['Abbrev']['HTH']->type, HTMLPurifier_VarParser::STRING);
 | |
|         $this->assertIdentical($this->schema->info['Abbrev']['HTH']->allowed, 
 | |
|             array(
 | |
|                 'Happy to Help' => true,
 | |
|                 'Hope that Helps' => true,
 | |
|                 'HAIL THE HAND!' => true
 | |
|             )
 | |
|         );
 | |
|         $this->assertIdentical($this->schema->info['Abbrev']['HTH']->aliases,
 | |
|         array(
 | |
|                 'happy' => 'Happy to Help',
 | |
|                 'hope' => 'Hope that Helps',
 | |
|                 'hail' => 'HAIL THE HAND!'
 | |
|             )
 | |
|         );
 | |
|         
 | |
|     }
 | |
|    
 | |
|     function testAlias() {
 | |
|         $this->schema->addNamespace('Home');
 | |
|         $this->schema->add('Home', 'Rug', 3, 'int', false);
 | |
|         $this->schema->addAlias('Home', 'Carpet', 'Home', 'Rug');
 | |
|         
 | |
|         $this->assertTrue(!isset($this->schema->defaults['Home']['Carpet']));
 | |
|         $this->assertIdentical($this->schema->info['Home']['Carpet']->namespace, 'Home');
 | |
|         $this->assertIdentical($this->schema->info['Home']['Carpet']->name, 'Rug');
 | |
|         $this->assertIdentical($this->schema->info['Home']['Carpet']->isAlias, true);
 | |
|         
 | |
|     }
 | |
|     
 | |
| }
 | |
| 
 |