old_copy = HTMLPurifier_ConfigSchema::instance(); $this->our_copy =& HTMLPurifier_ConfigSchema::instance($our_copy); } function tearDown() { HTMLPurifier_ConfigSchema::instance($this->old_copy); } function test() { HTMLPurifier_ConfigSchema::defineNamespace('Core', 'Corestuff'); HTMLPurifier_ConfigSchema::defineNamespace('Attr', 'Attributes'); HTMLPurifier_ConfigSchema::defineNamespace('Extension', 'Extensible'); HTMLPurifier_ConfigSchema::define( 'Core', 'Key', false, 'bool', 'A boolean directive.' ); HTMLPurifier_ConfigSchema::define( 'Attr', 'Key', 42, 'int', 'An integer directive.' ); HTMLPurifier_ConfigSchema::define( 'Extension', 'Pert', 'foo', 'string', 'A string directive.' ); HTMLPurifier_ConfigSchema::define( 'Core', 'Encoding', 'utf-8', 'istring', 'Case insensitivity!' ); HTMLPurifier_ConfigSchema::define( 'Extension', 'CanBeNull', null, 'string/null', 'Null or string!' ); HTMLPurifier_ConfigSchema::defineAllowedValues( 'Extension', 'Pert', array('foo', 'moo') ); HTMLPurifier_ConfigSchema::defineValueAliases( 'Extension', 'Pert', array('cow' => 'moo') ); HTMLPurifier_ConfigSchema::defineAllowedValues( 'Core', 'Encoding', array('utf-8', 'iso-8859-1') ); $config = HTMLPurifier_Config::createDefault(); // test default value retrieval $this->assertIdentical($config->get('Core', 'Key'), false); $this->assertIdentical($config->get('Attr', 'Key'), 42); $this->assertIdentical($config->get('Extension', 'Pert'), 'foo'); // set some values $config->set('Core', 'Key', true); $this->assertIdentical($config->get('Core', 'Key'), true); // try to retrieve undefined value $this->expectError('Cannot retrieve value of undefined directive'); $config->get('Core', 'NotDefined'); // try to set undefined value $this->expectError('Cannot set undefined directive to value'); $config->set('Foobar', 'Key', 'foobar'); // try to set not allowed value $this->expectError('Value not supported'); $config->set('Extension', 'Pert', 'wizard'); // try to set not allowed value $this->expectError('Value is of invalid type'); $config->set('Extension', 'Pert', 34); // set aliased value $config->set('Extension', 'Pert', 'cow'); $this->assertIdentical($config->get('Extension', 'Pert'), 'moo'); // case-insensitive attempt to set value that is allowed $config->set('Core', 'Encoding', 'ISO-8859-1'); $this->assertIdentical($config->get('Core', 'Encoding'), 'iso-8859-1'); // set null to directive that allows null $config->set('Extension', 'CanBeNull', null); $this->assertIdentical($config->get('Extension', 'CanBeNull'), null); $config->set('Extension', 'CanBeNull', 'foobar'); $this->assertIdentical($config->get('Extension', 'CanBeNull'), 'foobar'); // set null to directive that doesn't allow null $this->expectError('Value is of invalid type'); $config->set('Extension', 'Pert', null); // grab a namespace $config->set('Attr', 'Key', 0xBEEF); $this->assertIdentical( $config->getBatch('Attr'), array( 'Key' => 0xBEEF ) ); // grab a non-existant namespace $this->expectError('Cannot retrieve undefined namespace'); $config->getBatch('FurnishedGoods'); } function test_getDefinition() { // we actually want to use the old copy, because the definition // generation routines have dependencies on configuration values $this->old_copy = HTMLPurifier_ConfigSchema::instance($this->old_copy); $config = HTMLPurifier_Config::createDefault(); $def = $config->getHTMLDefinition(); $this->assertIsA($def, 'HTMLPurifier_HTMLDefinition'); $def = $config->getCSSDefinition(); $this->assertIsA($def, 'HTMLPurifier_CSSDefinition'); } function test_loadArray() { // setup a few dummy namespaces/directives for our testing HTMLPurifier_ConfigSchema::defineNamespace('Zoo', 'Animals we have.'); HTMLPurifier_ConfigSchema::define('Zoo', 'Aadvark', 0, 'int', 'Have?'); HTMLPurifier_ConfigSchema::define('Zoo', 'Boar', 0, 'int', 'Have?'); HTMLPurifier_ConfigSchema::define('Zoo', 'Camel', 0, 'int', 'Have?'); HTMLPurifier_ConfigSchema::define( 'Zoo', 'Others', array(), 'list', 'Other animals we have one of.' ); $config_manual = HTMLPurifier_Config::createDefault(); $config_loadabbr = HTMLPurifier_Config::createDefault(); $config_loadfull = HTMLPurifier_Config::createDefault(); $config_manual->set('Zoo', 'Aadvark', 3); $config_manual->set('Zoo', 'Boar', 5); $config_manual->set('Zoo', 'Camel', 2000); // that's a lotta camels! $config_manual->set('Zoo', 'Others', array('Peacock', 'Dodo')); // wtf! // condensed form $config_loadabbr->loadArray(array( 'Zoo.Aadvark' => 3, 'Zoo.Boar' => 5, 'Zoo.Camel' => 2000, 'Zoo.Others' => array('Peacock', 'Dodo') )); // fully expanded form $config_loadfull->loadArray(array( 'Zoo' => array( 'Aadvark' => 3, 'Boar' => 5, 'Camel' => 2000, 'Others' => array('Peacock', 'Dodo') ) )); $this->assertEqual($config_manual, $config_loadabbr); $this->assertEqual($config_manual, $config_loadfull); } function test_create() { HTMLPurifier_ConfigSchema::defineNamespace('Cake', 'Properties of it.'); HTMLPurifier_ConfigSchema::define('Cake', 'Sprinkles', 666, 'int', 'Number of.'); HTMLPurifier_ConfigSchema::define('Cake', 'Flavor', 'vanilla', 'string', 'Flavor of the batter.'); $config = HTMLPurifier_Config::createDefault(); $config->set('Cake', 'Sprinkles', 42); // test flat pass-through $created_config = HTMLPurifier_Config::create($config); $this->assertEqual($config, $created_config); // test loadArray $created_config = HTMLPurifier_Config::create(array('Cake.Sprinkles' => 42)); $this->assertEqual($config, $created_config); } function testAliases() { HTMLPurifier_ConfigSchema::defineNamespace('Home', 'Sweet home.'); HTMLPurifier_ConfigSchema::define('Home', 'Rug', 3, 'int', 'ID.'); HTMLPurifier_ConfigSchema::defineAlias('Home', 'Carpet', 'Home', 'Rug'); $config = HTMLPurifier_Config::createDefault(); $this->assertEqual($config->get('Home', 'Rug'), 3); $this->expectError('Cannot get value from aliased directive, use real name'); $config->get('Home', 'Carpet'); $config->set('Home', 'Carpet', 999); $this->assertEqual($config->get('Home', 'Rug'), 999); } } ?>