mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-08-02 12:21:09 +02:00
[1.4.0] Revamp ConfigSchema tests, add more error checking.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@670 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
@@ -106,6 +106,11 @@ class HTMLPurifier_ConfigSchema {
|
|||||||
E_USER_ERROR);
|
E_USER_ERROR);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (empty($description)) {
|
||||||
|
trigger_error('Description must be non-empty',
|
||||||
|
E_USER_ERROR);
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (isset($def->info[$namespace][$name])) {
|
if (isset($def->info[$namespace][$name])) {
|
||||||
if (
|
if (
|
||||||
$def->info[$namespace][$name]->type !== $type ||
|
$def->info[$namespace][$name]->type !== $type ||
|
||||||
@@ -161,6 +166,11 @@ class HTMLPurifier_ConfigSchema {
|
|||||||
E_USER_ERROR);
|
E_USER_ERROR);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (empty($description)) {
|
||||||
|
trigger_error('Description must be non-empty',
|
||||||
|
E_USER_ERROR);
|
||||||
|
return;
|
||||||
|
}
|
||||||
$def->info[$namespace] = array();
|
$def->info[$namespace] = array();
|
||||||
$def->info_namespace[$namespace] = new HTMLPurifier_ConfigEntity_Namespace();
|
$def->info_namespace[$namespace] = new HTMLPurifier_ConfigEntity_Namespace();
|
||||||
$def->info_namespace[$namespace]->description = $description;
|
$def->info_namespace[$namespace]->description = $description;
|
||||||
@@ -216,11 +226,25 @@ class HTMLPurifier_ConfigSchema {
|
|||||||
E_USER_ERROR);
|
E_USER_ERROR);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ($def->info[$namespace][$name]->allowed === true) {
|
$directive =& $def->info[$namespace][$name];
|
||||||
$def->info[$namespace][$name]->allowed = array();
|
$type = $directive->type;
|
||||||
|
if ($type != 'string' && $type != 'istring') {
|
||||||
|
trigger_error('Cannot define allowed values for directive whose type is not string',
|
||||||
|
E_USER_ERROR);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if ($directive->allowed === true) {
|
||||||
|
$directive->allowed = array();
|
||||||
}
|
}
|
||||||
foreach ($allowed_values as $value) {
|
foreach ($allowed_values as $value) {
|
||||||
$def->info[$namespace][$name]->allowed[$value] = true;
|
$directive->allowed[$value] = true;
|
||||||
|
}
|
||||||
|
if ($def->defaults[$namespace][$name] !== null &&
|
||||||
|
!isset($directive->allowed[$def->defaults[$namespace][$name]])) {
|
||||||
|
trigger_error('Default value must be in allowed range of variables',
|
||||||
|
E_USER_ERROR);
|
||||||
|
$directive->allowed = true; // undo undo!
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -235,7 +259,7 @@ class HTMLPurifier_ConfigSchema {
|
|||||||
function defineAlias($namespace, $name, $new_namespace, $new_name) {
|
function defineAlias($namespace, $name, $new_namespace, $new_name) {
|
||||||
$def =& HTMLPurifier_ConfigSchema::instance();
|
$def =& HTMLPurifier_ConfigSchema::instance();
|
||||||
if (!isset($def->info[$namespace])) {
|
if (!isset($def->info[$namespace])) {
|
||||||
trigger_error('Cannot define directive alias for undefined namespace',
|
trigger_error('Cannot define directive alias in undefined namespace',
|
||||||
E_USER_ERROR);
|
E_USER_ERROR);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -259,9 +283,9 @@ class HTMLPurifier_ConfigSchema {
|
|||||||
E_USER_ERROR);
|
E_USER_ERROR);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$def->info[$namespace][$name] = new HTMLPurifier_ConfigEntity_DirectiveAlias();
|
$def->info[$namespace][$name] =
|
||||||
$def->info[$namespace][$name]->namespace = $new_namespace;
|
new HTMLPurifier_ConfigEntity_DirectiveAlias(
|
||||||
$def->info[$namespace][$name]->name = $new_name;
|
$new_namespace, $new_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -367,6 +391,10 @@ class HTMLPurifier_ConfigEntity {
|
|||||||
*/
|
*/
|
||||||
class HTMLPurifier_ConfigEntity_Namespace extends HTMLPurifier_ConfigEntity {
|
class HTMLPurifier_ConfigEntity_Namespace extends HTMLPurifier_ConfigEntity {
|
||||||
|
|
||||||
|
function HTMLPurifier_ConfigEntity_Namespace($description = null) {
|
||||||
|
$this->description = $description;
|
||||||
|
}
|
||||||
|
|
||||||
var $class = 'namespace';
|
var $class = 'namespace';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -385,15 +413,19 @@ class HTMLPurifier_ConfigEntity_Directive extends HTMLPurifier_ConfigEntity
|
|||||||
|
|
||||||
var $class = 'directive';
|
var $class = 'directive';
|
||||||
|
|
||||||
/**
|
function HTMLPurifier_ConfigEntity_Directive(
|
||||||
* Hash of value aliases, i.e. values that are equivalent.
|
$type = null,
|
||||||
*/
|
$descriptions = null,
|
||||||
var $aliases = array();
|
$allow_null = null,
|
||||||
|
$allowed = null,
|
||||||
/**
|
$aliases = null
|
||||||
* Lookup table of allowed values of the element, bool true if all allowed.
|
) {
|
||||||
*/
|
if ( $type !== null) $this->type = $type;
|
||||||
var $allowed = true;
|
if ($descriptions !== null) $this->descriptions = $descriptions;
|
||||||
|
if ( $allow_null !== null) $this->allow_null = $allow_null;
|
||||||
|
if ( $allowed !== null) $this->allowed = $allowed;
|
||||||
|
if ( $aliases !== null) $this->aliases = $aliases;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allowed type of the directive. Values are:
|
* Allowed type of the directive. Values are:
|
||||||
@@ -410,16 +442,26 @@ class HTMLPurifier_ConfigEntity_Directive extends HTMLPurifier_ConfigEntity
|
|||||||
var $type = 'mixed';
|
var $type = 'mixed';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is null allowed? Has no affect for mixed type.
|
* Plaintext descriptions of the configuration entity is. Organized by
|
||||||
|
* file and line number, so multiple descriptions are allowed.
|
||||||
|
*/
|
||||||
|
var $descriptions = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Is null allowed? Has no effect for mixed type.
|
||||||
* @bool
|
* @bool
|
||||||
*/
|
*/
|
||||||
var $allow_null = false;
|
var $allow_null = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Plaintext descriptions of the configuration entity is. Organized by
|
* Lookup table of allowed values of the element, bool true if all allowed.
|
||||||
* file and line number, so multiple descriptions are allowed.
|
|
||||||
*/
|
*/
|
||||||
var $descriptions = array();
|
var $allowed = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hash of value aliases, i.e. values that are equivalent.
|
||||||
|
*/
|
||||||
|
var $aliases = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a description to the array
|
* Adds a description to the array
|
||||||
@@ -446,6 +488,11 @@ class HTMLPurifier_ConfigEntity_DirectiveAlias extends HTMLPurifier_ConfigEntity
|
|||||||
* Directive being aliased to
|
* Directive being aliased to
|
||||||
*/
|
*/
|
||||||
var $name;
|
var $name;
|
||||||
|
|
||||||
|
function HTMLPurifier_ConfigEntity_DirectiveAlias($namespace, $name) {
|
||||||
|
$this->namespace = $namespace;
|
||||||
|
$this->name = $name;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
@@ -2,10 +2,24 @@
|
|||||||
|
|
||||||
require_once 'HTMLPurifier/ConfigSchema.php';
|
require_once 'HTMLPurifier/ConfigSchema.php';
|
||||||
|
|
||||||
|
class CS extends HTMLPurifier_ConfigSchema {} // alias for less keystrokes
|
||||||
|
|
||||||
class HTMLPurifier_ConfigSchemaTest extends UnitTestCase
|
class HTMLPurifier_ConfigSchemaTest extends UnitTestCase
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Munged name of current file.
|
||||||
|
*/
|
||||||
|
var $file;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy of the real ConfigSchema to revert to.
|
||||||
|
*/
|
||||||
var $old_copy;
|
var $old_copy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy of dummy ConfigSchema for testing purposes.
|
||||||
|
*/
|
||||||
var $our_copy;
|
var $our_copy;
|
||||||
|
|
||||||
function setUp() {
|
function setUp() {
|
||||||
@@ -18,251 +32,229 @@ class HTMLPurifier_ConfigSchemaTest extends UnitTestCase
|
|||||||
$this->old_copy = HTMLPurifier_ConfigSchema::instance();
|
$this->old_copy = HTMLPurifier_ConfigSchema::instance();
|
||||||
// put in our copy, and reassign to the REAL reference
|
// put in our copy, and reassign to the REAL reference
|
||||||
$this->our_copy =& HTMLPurifier_ConfigSchema::instance($our_copy);
|
$this->our_copy =& HTMLPurifier_ConfigSchema::instance($our_copy);
|
||||||
|
|
||||||
|
$this->file = $this->our_copy->mungeFilename(__FILE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
function tearDown() {
|
function tearDown() {
|
||||||
// testing is done, restore the old copy
|
// testing is done, restore the old copy
|
||||||
HTMLPurifier_ConfigSchema::instance($this->old_copy);
|
HTMLPurifier_ConfigSchema::instance($this->old_copy);
|
||||||
|
$this->tallyErrors();
|
||||||
}
|
}
|
||||||
|
|
||||||
function testNormal() {
|
function tallyErrors() {
|
||||||
|
// BRITTLE: relies on private code to work
|
||||||
|
$context = &SimpleTest::getContext();
|
||||||
|
$queue = &$context->get('SimpleErrorQueue');
|
||||||
|
if (!isset($queue->_expectation_queue)) return; // fut-compat
|
||||||
|
foreach ($queue->_expectation_queue as $e) {
|
||||||
|
if (count($e) != 2) return; // fut-compat
|
||||||
|
if (!isset($e[0])) return; // fut-compat
|
||||||
|
$e[0]->_dumper = &new SimpleDumper();
|
||||||
|
$this->fail('Error expectation not fulfilled: ' .
|
||||||
|
$e[0]->testMessage(null));
|
||||||
|
}
|
||||||
|
$queue->_expectation_queue = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
function test_defineNamespace() {
|
||||||
|
CS::defineNamespace('http', $d = 'This is an internet protocol.');
|
||||||
|
|
||||||
$file = $this->our_copy->mungeFilename(__FILE__);
|
|
||||||
|
|
||||||
// define a namespace
|
|
||||||
$description = 'Configuration that is always available.';
|
|
||||||
HTMLPurifier_ConfigSchema::defineNamespace(
|
|
||||||
'Core', $description
|
|
||||||
);
|
|
||||||
$this->assertIdentical($this->our_copy->defaults, array(
|
|
||||||
'Core' => array()
|
|
||||||
));
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array()
|
|
||||||
));
|
|
||||||
$namespace = new HTMLPurifier_ConfigEntity_Namespace();
|
|
||||||
$namespace->description = $description;
|
|
||||||
$this->assertIdentical($this->our_copy->info_namespace, array(
|
$this->assertIdentical($this->our_copy->info_namespace, array(
|
||||||
'Core' => $namespace
|
'http' => new HTMLPurifier_ConfigEntity_Namespace($d)
|
||||||
));
|
));
|
||||||
|
|
||||||
|
$this->expectError('Cannot redefine namespace');
|
||||||
|
CS::defineNamespace('http', 'It is used to serve webpages.');
|
||||||
|
|
||||||
|
|
||||||
// define a directive
|
|
||||||
$description = 'This is a description of the directive.';
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Name', 'default value', 'string',
|
|
||||||
$description
|
|
||||||
); $line = __LINE__;
|
|
||||||
$this->assertIdentical($this->our_copy->defaults, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => 'default value'
|
|
||||||
)
|
|
||||||
));
|
|
||||||
$directive = new HTMLPurifier_ConfigEntity_Directive();
|
|
||||||
$directive->type = 'string';
|
|
||||||
$directive->addDescription($file, $line, $description);
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => $directive
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// define a directive in an undefined namespace
|
|
||||||
$this->expectError('Cannot define directive for undefined namespace');
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Extension', 'Name', false, 'bool',
|
|
||||||
'This is for an extension, but we have not defined its namespace!'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// redefine a value in a valid manner
|
|
||||||
$description = 'Alternative configuration definition';
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Name', 'default value', 'string',
|
|
||||||
$description
|
|
||||||
); $line = __LINE__;
|
|
||||||
|
|
||||||
$directive->addDescription($file, $line, $description);
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => $directive
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// redefine a directive in an invalid manner
|
|
||||||
$this->expectError('Inconsistent default or type, cannot redefine');
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Name', 'different default', 'string',
|
|
||||||
'Inconsistent default or type, cannot redefine'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// make an enumeration
|
|
||||||
HTMLPurifier_ConfigSchema::defineAllowedValues(
|
|
||||||
'Core', 'Name', array(
|
|
||||||
'Real Value',
|
|
||||||
'Real Value 2'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$directive->allowed = array(
|
|
||||||
'Real Value' => true,
|
|
||||||
'Real Value 2' => true
|
|
||||||
);
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => $directive
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// redefinition of enumeration is cumulative
|
|
||||||
HTMLPurifier_ConfigSchema::defineAllowedValues(
|
|
||||||
'Core', 'Name', array(
|
|
||||||
'Real Value 3',
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$directive->allowed['Real Value 3'] = true;
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => $directive
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// cannot define enumeration for undefined directive
|
|
||||||
$this->expectError('Cannot define allowed values for undefined directive');
|
|
||||||
HTMLPurifier_ConfigSchema::defineAllowedValues(
|
|
||||||
'Core', 'Foobar', array(
|
|
||||||
'Real Value 9',
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// test defining value aliases for an enumerated value
|
|
||||||
HTMLPurifier_ConfigSchema::defineValueAliases(
|
|
||||||
'Core', 'Name', array(
|
|
||||||
'Aliased Value' => 'Real Value'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$directive->aliases['Aliased Value'] = 'Real Value';
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => $directive
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// redefine should be cumulative
|
|
||||||
HTMLPurifier_ConfigSchema::defineValueAliases(
|
|
||||||
'Core', 'Name', array(
|
|
||||||
'Aliased Value 2' => 'Real Value 2'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$directive->aliases['Aliased Value 2'] = 'Real Value 2';
|
|
||||||
$this->assertIdentical($this->our_copy->info, array(
|
|
||||||
'Core' => array(
|
|
||||||
'Name' => $directive
|
|
||||||
)
|
|
||||||
));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// cannot create alias to not-allowed value
|
|
||||||
$this->expectError('Cannot define alias to value that is not allowed');
|
|
||||||
HTMLPurifier_ConfigSchema::defineValueAliases(
|
|
||||||
'Core', 'Name', array(
|
|
||||||
'Aliased Value 3' => 'Invalid Value'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// cannot create alias for already allowed value
|
|
||||||
$this->expectError('Cannot define alias over allowed value');
|
|
||||||
HTMLPurifier_ConfigSchema::defineValueAliases(
|
|
||||||
'Core', 'Name', array(
|
|
||||||
'Real Value' => 'Real Value 2'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// define a directive with an invalid type
|
|
||||||
$this->expectError('Invalid type for configuration directive');
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Foobar', false, 'omen',
|
|
||||||
'Omen is not a valid type, so we reject this.'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// define a directive with inconsistent type
|
|
||||||
$this->expectError('Default value does not match directive type');
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Foobaz', 10, 'string',
|
|
||||||
'If we say string, we should mean it, not integer 10.'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// define a directive that allows null
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Foobaz', null, 'string/null',
|
|
||||||
'Nulls are allowed if you add on /null, cool huh?'
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// define a directive with bad characters
|
|
||||||
$this->expectError('Directive name must be alphanumeric');
|
|
||||||
HTMLPurifier_ConfigSchema::define(
|
|
||||||
'Core', 'Core.Attr', 10, 'int',
|
|
||||||
'No periods! >:-('
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
// define a namespace with bad characters
|
|
||||||
$this->expectError('Namespace name must be alphanumeric');
|
$this->expectError('Namespace name must be alphanumeric');
|
||||||
HTMLPurifier_ConfigSchema::defineNamespace(
|
CS::defineNamespace('ssh+http', 'This http is tunneled through SSH.');
|
||||||
'Foobar&Gromit', $description
|
|
||||||
|
$this->expectError('Description must be non-empty');
|
||||||
|
CS::defineNamespace('ftp', null);
|
||||||
|
}
|
||||||
|
|
||||||
|
function test_define() {
|
||||||
|
CS::defineNamespace('Car', 'Automobiles, those gas-guzzlers!');
|
||||||
|
|
||||||
|
CS::define('Car', 'Seats', 5, 'int', $d = 'Standard issue.'); $l = __LINE__;
|
||||||
|
|
||||||
|
$this->assertIdentical($this->our_copy->defaults['Car']['Seats'], 5);
|
||||||
|
$this->assertIdentical($this->our_copy->info['Car']['Seats'],
|
||||||
|
new HTMLPurifier_ConfigEntity_Directive('int',
|
||||||
|
array($this->file => array($l => $d))
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
CS::define('Car', 'Age', null, 'int/null', $d = 'Not always known.'); $l = __LINE__;
|
||||||
|
|
||||||
// alias related tests
|
$this->assertIdentical($this->our_copy->defaults['Car']['Age'], null);
|
||||||
|
$this->assertIdentical($this->our_copy->info['Car']['Age'],
|
||||||
|
new HTMLPurifier_ConfigEntity_Directive('int',
|
||||||
|
array($this->file => array($l => $d)), true
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
HTMLPurifier_ConfigSchema::defineNamespace('Home', 'Sweet home.');
|
$this->expectError('Cannot define directive for undefined namespace');
|
||||||
HTMLPurifier_ConfigSchema::define('Home', 'Rug', 3, 'int', 'ID.');
|
CS::define('Train', 'Cars', 10, 'int', 'Including the caboose.');
|
||||||
HTMLPurifier_ConfigSchema::defineAlias('Home', 'Carpet', 'Home', 'Rug');
|
|
||||||
|
|
||||||
$this->expectError('Cannot define directive alias for undefined namespace');
|
|
||||||
HTMLPurifier_ConfigSchema::defineAlias('Store', 'Rug', 'Home', 'Rug');
|
|
||||||
|
|
||||||
$this->expectError('Directive name must be alphanumeric');
|
$this->expectError('Directive name must be alphanumeric');
|
||||||
HTMLPurifier_ConfigSchema::defineAlias('Home', 'R.g', 'Home', 'Rug');
|
CS::define('Car', 'Is it shiny?', true, 'bool', 'Indicates regular waxing.');
|
||||||
|
|
||||||
HTMLPurifier_ConfigSchema::define('Home', 'Rugger', 'Bob Max', 'string', 'Name of.');
|
$this->expectError('Invalid type for configuration directive');
|
||||||
|
CS::define('Car', 'Efficiency', 50, 'mpg', 'The higher the better.');
|
||||||
|
|
||||||
|
$this->expectError('Default value does not match directive type');
|
||||||
|
CS::define('Car', 'Producer', 'Ford', 'int', 'ID of the company that made the car.');
|
||||||
|
|
||||||
|
$this->expectError('Description must be non-empty');
|
||||||
|
CS::define('Car', 'ComplexAttribute', 'lawyers', 'istring', null);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testRedefinition_define() {
|
||||||
|
CS::defineNamespace('Cat', 'Belongs to Schrodinger.');
|
||||||
|
|
||||||
|
CS::define('Cat', 'Dead', false, 'bool', $d1 = 'Well, is it?'); $l1 = __LINE__;
|
||||||
|
CS::define('Cat', 'Dead', false, 'bool', $d2 = 'It is difficult to say.'); $l2 = __LINE__;
|
||||||
|
|
||||||
|
$this->assertIdentical($this->our_copy->defaults['Cat']['Dead'], false);
|
||||||
|
$this->assertIdentical($this->our_copy->info['Cat']['Dead'],
|
||||||
|
new HTMLPurifier_ConfigEntity_Directive('bool',
|
||||||
|
array($this->file => array($l1 => $d1, $l2 => $d2))
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Inconsistent default or type, cannot redefine');
|
||||||
|
CS::define('Cat', 'Dead', true, 'bool', 'Quantum mechanics does not know.');
|
||||||
|
|
||||||
|
$this->expectError('Inconsistent default or type, cannot redefine');
|
||||||
|
CS::define('Cat', 'Dead', 'maybe', 'string', 'Perhaps if we look we will know.');
|
||||||
|
}
|
||||||
|
|
||||||
|
function test_defineAllowedValues() {
|
||||||
|
CS::defineNamespace('QuantumNumber', 'D');
|
||||||
|
CS::define('QuantumNumber', 'Spin', 0.5, 'float',
|
||||||
|
'Spin of particle. Fourth quantum number, represented by s.');
|
||||||
|
CS::define('QuantumNumber', 'Current', 's', 'string',
|
||||||
|
'Currently selected quantum number.');
|
||||||
|
CS::define('QuantumNumber', 'Difficulty', null, 'string/null', $d = 'How hard are the problems?'); $l = __LINE__;
|
||||||
|
|
||||||
|
CS::defineAllowedValues( // okay, since default is null
|
||||||
|
'QuantumNumber', 'Difficulty', array('easy', 'medium', 'hard')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertIdentical($this->our_copy->defaults['QuantumNumber']['Difficulty'], null);
|
||||||
|
$this->assertIdentical($this->our_copy->info['QuantumNumber']['Difficulty'],
|
||||||
|
new HTMLPurifier_ConfigEntity_Directive(
|
||||||
|
'string',
|
||||||
|
array($this->file => array($l => $d)),
|
||||||
|
true,
|
||||||
|
array(
|
||||||
|
'easy' => true,
|
||||||
|
'medium' => true,
|
||||||
|
'hard' => true
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Cannot define allowed values for undefined directive');
|
||||||
|
CS::defineAllowedValues(
|
||||||
|
'SpaceTime', 'Symmetry', array('time', 'spatial', 'projective')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Cannot define allowed values for directive whose type is not string');
|
||||||
|
CS::defineAllowedValues(
|
||||||
|
'QuantumNumber', 'Spin', array(0.5, -0.5)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Default value must be in allowed range of variables');
|
||||||
|
CS::defineAllowedValues(
|
||||||
|
'QuantumNumber', 'Current', array('n', 'l', 'm') // forgot s!
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function test_defineValueAliases() {
|
||||||
|
CS::defineNamespace('Abbrev', 'Stuff on abbreviations.');
|
||||||
|
CS::define('Abbrev', 'HTH', 'Happy to Help', 'string', $d = 'Three-letters'); $l = __LINE__;
|
||||||
|
CS::defineAllowedValues(
|
||||||
|
'Abbrev', 'HTH', array(
|
||||||
|
'Happy to Help',
|
||||||
|
'Hope that Helps',
|
||||||
|
'HAIL THE HAND!'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
CS::defineValueAliases(
|
||||||
|
'Abbrev', 'HTH', array(
|
||||||
|
'happy' => 'Happy to Help',
|
||||||
|
'hope' => 'Hope that Helps'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
CS::defineValueAliases( // delayed addition
|
||||||
|
'Abbrev', 'HTH', array(
|
||||||
|
'hail' => 'HAIL THE HAND!'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertIdentical($this->our_copy->defaults['Abbrev']['HTH'], 'Happy to Help');
|
||||||
|
$this->assertIdentical($this->our_copy->info['Abbrev']['HTH'],
|
||||||
|
new HTMLPurifier_ConfigEntity_Directive(
|
||||||
|
'string',
|
||||||
|
array($this->file => array($l => $d)),
|
||||||
|
false,
|
||||||
|
array(
|
||||||
|
'Happy to Help' => true,
|
||||||
|
'Hope that Helps' => true,
|
||||||
|
'HAIL THE HAND!' => true
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'happy' => 'Happy to Help',
|
||||||
|
'hope' => 'Hope that Helps',
|
||||||
|
'hail' => 'HAIL THE HAND!'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Cannot define alias to value that is not allowed');
|
||||||
|
CS::defineValueAliases(
|
||||||
|
'Abbrev', 'HTH', array(
|
||||||
|
'head' => 'Head to Head'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Cannot define alias over allowed value');
|
||||||
|
CS::defineValueAliases(
|
||||||
|
'Abbrev', 'HTH', array(
|
||||||
|
'Hope that Helps' => 'Happy to Help'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function testAlias() {
|
||||||
|
CS::defineNamespace('Home', 'Sweet home.');
|
||||||
|
CS::define('Home', 'Rug', 3, 'int', 'ID.');
|
||||||
|
CS::defineAlias('Home', 'Carpet', 'Home', 'Rug');
|
||||||
|
|
||||||
|
$this->assertTrue(!isset($this->our_copy->defaults['Home']['Carpet']));
|
||||||
|
$this->assertIdentical($this->our_copy->info['Home']['Carpet'],
|
||||||
|
new HTMLPurifier_ConfigEntity_DirectiveAlias('Home', 'Rug')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->expectError('Cannot define directive alias in undefined namespace');
|
||||||
|
CS::defineAlias('Store', 'Rug', 'Home', 'Rug');
|
||||||
|
|
||||||
|
$this->expectError('Directive name must be alphanumeric');
|
||||||
|
CS::defineAlias('Home', 'R.g', 'Home', 'Rug');
|
||||||
|
|
||||||
|
CS::define('Home', 'Rugger', 'Bob Max', 'string', 'Name of.');
|
||||||
$this->expectError('Cannot define alias over directive');
|
$this->expectError('Cannot define alias over directive');
|
||||||
HTMLPurifier_ConfigSchema::defineAlias('Home', 'Rugger', 'Home', 'Rug');
|
CS::defineAlias('Home', 'Rugger', 'Home', 'Rug');
|
||||||
|
|
||||||
$this->expectError('Cannot define alias to undefined directive');
|
$this->expectError('Cannot define alias to undefined directive');
|
||||||
HTMLPurifier_ConfigSchema::defineAlias('Home', 'Rug2', 'Home', 'Rugavan');
|
CS::defineAlias('Home', 'Rug2', 'Home', 'Rugavan');
|
||||||
|
|
||||||
$this->expectError('Cannot define alias to alias');
|
$this->expectError('Cannot define alias to alias');
|
||||||
HTMLPurifier_ConfigSchema::defineAlias('Home', 'Rug2', 'Home', 'Carpet');
|
CS::defineAlias('Home', 'Rug2', 'Home', 'Carpet');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function assertValid($var, $type, $ret = null) {
|
function assertValid($var, $type, $ret = null) {
|
||||||
@@ -282,25 +274,32 @@ class HTMLPurifier_ConfigSchemaTest extends UnitTestCase
|
|||||||
|
|
||||||
$this->assertValid('foobar', 'string');
|
$this->assertValid('foobar', 'string');
|
||||||
$this->assertValid('FOOBAR', 'istring', 'foobar');
|
$this->assertValid('FOOBAR', 'istring', 'foobar');
|
||||||
|
|
||||||
$this->assertValid(34, 'int');
|
$this->assertValid(34, 'int');
|
||||||
|
|
||||||
$this->assertValid(3.34, 'float');
|
$this->assertValid(3.34, 'float');
|
||||||
|
|
||||||
$this->assertValid(false, 'bool');
|
$this->assertValid(false, 'bool');
|
||||||
$this->assertValid(0, 'bool', false);
|
$this->assertValid(0, 'bool', false);
|
||||||
$this->assertValid(1, 'bool', true);
|
$this->assertValid(1, 'bool', true);
|
||||||
$this->assertInvalid(34, 'bool');
|
|
||||||
$this->assertInvalid(null, 'bool');
|
|
||||||
$this->assertValid(array('1', '2', '3'), 'list');
|
|
||||||
$this->assertValid(array('1' => true, '2' => true), 'lookup');
|
|
||||||
$this->assertValid(array('1', '2'), 'lookup', array('1' => true, '2' => true));
|
|
||||||
$this->assertValid(array('foo' => 'bar'), 'hash');
|
|
||||||
$this->assertInvalid(array(0 => 'moo'), 'hash');
|
|
||||||
$this->assertValid(array(1 => 'moo'), 'hash');
|
|
||||||
$this->assertValid(23, 'mixed');
|
|
||||||
$this->assertValid('foo,bar, cow', 'list', array('foo', 'bar', 'cow'));
|
|
||||||
$this->assertValid('foo,bar', 'lookup', array('foo' => true, 'bar' => true));
|
|
||||||
$this->assertValid('true', 'bool', true);
|
$this->assertValid('true', 'bool', true);
|
||||||
$this->assertValid('false', 'bool', false);
|
$this->assertValid('false', 'bool', false);
|
||||||
$this->assertValid('1', 'bool', true);
|
$this->assertValid('1', 'bool', true);
|
||||||
|
$this->assertInvalid(34, 'bool');
|
||||||
|
$this->assertInvalid(null, 'bool');
|
||||||
|
|
||||||
|
$this->assertValid(array('1', '2', '3'), 'list');
|
||||||
|
$this->assertValid('foo,bar, cow', 'list', array('foo', 'bar', 'cow'));
|
||||||
|
|
||||||
|
$this->assertValid(array('1' => true, '2' => true), 'lookup');
|
||||||
|
$this->assertValid(array('1', '2'), 'lookup', array('1' => true, '2' => true));
|
||||||
|
$this->assertValid('foo,bar', 'lookup', array('foo' => true, 'bar' => true));
|
||||||
|
|
||||||
|
$this->assertValid(array('foo' => 'bar'), 'hash');
|
||||||
|
$this->assertValid(array(1 => 'moo'), 'hash');
|
||||||
|
$this->assertInvalid(array(0 => 'moo'), 'hash');
|
||||||
|
|
||||||
|
$this->assertValid(23, 'mixed');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -330,12 +329,12 @@ class HTMLPurifier_ConfigSchemaTest extends UnitTestCase
|
|||||||
function testMungeFilename() {
|
function testMungeFilename() {
|
||||||
|
|
||||||
$this->assertMungeFilename(
|
$this->assertMungeFilename(
|
||||||
'C:\\php\\libs\\htmlpurifier\\library\\HTMLPurifier\\AttrDef.php',
|
'C:\\php\\My Libraries\\htmlpurifier\\library\\HTMLPurifier\\AttrDef.php',
|
||||||
'HTMLPurifier/AttrDef.php'
|
'HTMLPurifier/AttrDef.php'
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->assertMungeFilename(
|
$this->assertMungeFilename(
|
||||||
'C:\\php\\libs\\htmlpurifier\\library\\HTMLPurifier.php',
|
'C:\\php\\My Libraries\\htmlpurifier\\library\\HTMLPurifier.php',
|
||||||
'HTMLPurifier.php'
|
'HTMLPurifier.php'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user