mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-26 15:10:00 +00:00
238678871e
- Defined new directive %Core.EscapeInvalidChildren, for previously commented out functionality - Removed convenience configuration generation: you *have* to pass it unless you're interfacing with HTMLPurifier - Homogenized function parameters even when only a few of them are used - Rewrote unit tests that expected previous behavior - Introduced configuration object to ChildDef tests git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@243 48356398-32a2-884e-a903-53898d9a118a
43 lines
1.3 KiB
PHP
43 lines
1.3 KiB
PHP
<?php
|
|
|
|
require_once 'HTMLPurifier/Definition.php';
|
|
require_once 'HTMLPurifier/Lexer/DirectLex.php';
|
|
|
|
class HTMLPurifier_StrategyHarness extends UnitTestCase
|
|
{
|
|
|
|
var $lex, $gen;
|
|
|
|
function HTMLPurifier_StrategyHarness() {
|
|
$this->UnitTestCase();
|
|
|
|
// we can't use the DOM lexer since it does too much stuff
|
|
// automatically, however, we should be able to use it
|
|
// interchangeably if we wanted to...
|
|
|
|
if (true) {
|
|
$this->lex = new HTMLPurifier_Lexer_DirectLex();
|
|
} else {
|
|
require_once 'HTMLPurifier/Lexer/DOMLex.php';
|
|
$this->lex = new HTMLPurifier_Lexer_DOMLex();
|
|
}
|
|
|
|
$this->gen = new HTMLPurifier_Generator();
|
|
}
|
|
|
|
function assertStrategyWorks($strategy, $inputs, $expect, $config = array()) {
|
|
foreach ($inputs as $i => $input) {
|
|
$tokens = $this->lex->tokenizeHTML($input);
|
|
if (!isset($config[$i])) {
|
|
$config[$i] = HTMLPurifier_Config::createDefault();
|
|
}
|
|
$result_tokens = $strategy->execute($tokens, $config[$i]);
|
|
$result = $this->gen->generateFromTokens($result_tokens);
|
|
$this->assertEqual($expect[$i], $result, "Test $i: %s");
|
|
paintIf($result, $result != $expect[$i]);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
?>
|