0
0
mirror of https://github.com/ezyang/htmlpurifier.git synced 2025-01-08 15:11:51 +00:00

[3.1.1] Land vs's HTMLPurifier_Generator patch, and a number of other bugfixes for that change

- Convert a number of calls to use new constructor signature for Generator
- Make generator require configuration; this exposes a number of latent bugs
- Removed generator hack
- Convert Printers to use new optimized ConfigSchema format
- Hack with Printer configuration; pass an array(generator config, render config) to distinguish between output and target.
- HTML/CSS Printers need to be primed, otherwise fatal errors
- Convert a few test-cases to use member properties

git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1770 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
Edward Z. Yang 2008-05-26 04:05:48 +00:00
parent bb16d8eae5
commit 14d934c7ca
12 changed files with 124 additions and 79 deletions

10
NEWS
View File

@ -23,6 +23,8 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
- Account for browser confusion between Yen character and backslash in - Account for browser confusion between Yen character and backslash in
Shift_JIS encoding. This fix generalizes to any other encoding which is not Shift_JIS encoding. This fix generalizes to any other encoding which is not
a strict superset of printable ASCII. a strict superset of printable ASCII.
- Fix missing configuration parameter in Generator calls. Thanks vs for the
partial patch.
. Added HTMLPurifier_UnitConverter and HTMLPurifier_Length for convenient . Added HTMLPurifier_UnitConverter and HTMLPurifier_Length for convenient
handling of CSS-style lengths. HTMLPurifier_AttrDef_CSS_Length now uses handling of CSS-style lengths. HTMLPurifier_AttrDef_CSS_Length now uses
this class. this class.
@ -42,6 +44,14 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
consult changes to HTMLPurifier_Config for details. consult changes to HTMLPurifier_Config for details.
. Variable parsing types now are magic integers instead of strings . Variable parsing types now are magic integers instead of strings
. Added benchmark for ConfigSchema . Added benchmark for ConfigSchema
. HTMLPurifier_Generator requires $config and $context parameters. If you
don't know what they should be, use HTMLPurifier_Config::createDefault()
and new HTMLPurifier_Context().
. Printers now properly distinguish between output configuration, and
target configuration. This is not applicable to scripts using
the Printers for HTML Purifier related tasks.
. HTML/CSS Printers must be primed with prepareGenerator($gen_config), otherwise
fatal errors will ensue.
3.1.0, released 2008-05-18 3.1.0, released 2008-05-18
# Unnecessary references to objects (vestiges of PHP4) removed from method # Unnecessary references to objects (vestiges of PHP4) removed from method

View File

@ -68,19 +68,19 @@
</directive> </directive>
<directive id="Core.Encoding"> <directive id="Core.Encoding">
<file name="HTMLPurifier/Encoder.php"> <file name="HTMLPurifier/Encoder.php">
<line>281</line> <line>288</line>
<line>305</line> <line>315</line>
</file> </file>
</directive> </directive>
<directive id="Test.ForceNoIconv"> <directive id="Test.ForceNoIconv">
<file name="HTMLPurifier/Encoder.php"> <file name="HTMLPurifier/Encoder.php">
<line>283</line> <line>293</line>
<line>310</line> <line>323</line>
</file> </file>
</directive> </directive>
<directive id="Core.EscapeNonASCIICharacters"> <directive id="Core.EscapeNonASCIICharacters">
<file name="HTMLPurifier/Encoder.php"> <file name="HTMLPurifier/Encoder.php">
<line>307</line> <line>319</line>
</file> </file>
</directive> </directive>
<directive id="Core.MaintainLineNumbers"> <directive id="Core.MaintainLineNumbers">
@ -96,17 +96,17 @@
</directive> </directive>
<directive id="Output.CommentScriptContents"> <directive id="Output.CommentScriptContents">
<file name="HTMLPurifier/Generator.php"> <file name="HTMLPurifier/Generator.php">
<line>41</line> <line>40</line>
</file> </file>
</directive> </directive>
<directive id="Output.TidyFormat"> <directive id="Output.TidyFormat">
<file name="HTMLPurifier/Generator.php"> <file name="HTMLPurifier/Generator.php">
<line>70</line> <line>69</line>
</file> </file>
</directive> </directive>
<directive id="Output.Newline"> <directive id="Output.Newline">
<file name="HTMLPurifier/Generator.php"> <file name="HTMLPurifier/Generator.php">
<line>84</line> <line>83</line>
</file> </file>
</directive> </directive>
<directive id="HTML.BlockWrapper"> <directive id="HTML.BlockWrapper">

View File

@ -55,10 +55,7 @@ class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
$escape_invalid_children = $config->get('Core', 'EscapeInvalidChildren'); $escape_invalid_children = $config->get('Core', 'EscapeInvalidChildren');
// generator // generator
static $gen = null; $gen = new HTMLPurifier_Generator($config, $context);
if ($gen === null) {
$gen = new HTMLPurifier_Generator();
}
foreach ($tokens_of_children as $token) { foreach ($tokens_of_children as $token) {
if (!empty($token->is_whitespace)) { if (!empty($token->is_whitespace)) {
@ -83,7 +80,7 @@ class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
$result[] = $token; $result[] = $token;
} elseif ($pcdata_allowed && $escape_invalid_children) { } elseif ($pcdata_allowed && $escape_invalid_children) {
$result[] = new HTMLPurifier_Token_Text( $result[] = new HTMLPurifier_Token_Text(
$gen->generateFromToken($token, $config) $gen->generateFromToken($token)
); );
} }
continue; continue;
@ -94,7 +91,7 @@ class HTMLPurifier_ChildDef_Required extends HTMLPurifier_ChildDef
} elseif ($pcdata_allowed && $escape_invalid_children) { } elseif ($pcdata_allowed && $escape_invalid_children) {
$result[] = $result[] =
new HTMLPurifier_Token_Text( new HTMLPurifier_Token_Text(
$gen->generateFromToken( $token, $config ) $gen->generateFromToken($token)
); );
} else { } else {
// drop silently // drop silently

View File

@ -35,8 +35,7 @@ class HTMLPurifier_Generator
* @param $config Instance of HTMLPurifier_Config * @param $config Instance of HTMLPurifier_Config
* @param $context Instance of HTMLPurifier_Context * @param $context Instance of HTMLPurifier_Context
*/ */
public function __construct($config = null, $context = null) { public function __construct($config, $context) {
if (!$config) $config = HTMLPurifier_Config::createDefault();
$this->config = $config; $this->config = $config;
$this->_scriptFix = $config->get('Output', 'CommentScriptContents'); $this->_scriptFix = $config->get('Output', 'CommentScriptContents');
$this->_def = $config->getHTMLDefinition(); $this->_def = $config->getHTMLDefinition();

View File

@ -20,18 +20,15 @@ class HTMLPurifier_Printer
* Initialize $generator. * Initialize $generator.
*/ */
public function __construct() { public function __construct() {
$this->generator = new HTMLPurifier_Generator();
} }
/** /**
* Give generator necessary configuration if possible * Give generator necessary configuration if possible
*/ */
public function prepareGenerator($config) { public function prepareGenerator($config) {
// hack for smoketests/configForm.php
$all = $config->getAll(); $all = $config->getAll();
if (empty($all['HTML'])) return;
$context = new HTMLPurifier_Context(); $context = new HTMLPurifier_Context();
$this->generator->generateFromTokens(array(), $config, $context); $this->generator = new HTMLPurifier_Generator($config, $context);
} }
/** /**

View File

@ -1,5 +1,8 @@
<?php <?php
/**
* @todo Rewrite to use Interchange objects
*/
class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
{ {
@ -38,8 +41,8 @@ class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
$this->name = $name; $this->name = $name;
$this->compress = $compress; $this->compress = $compress;
// initialize sub-printers // initialize sub-printers
$this->fields['default'] = new HTMLPurifier_Printer_ConfigForm_default(); $this->fields[0] = new HTMLPurifier_Printer_ConfigForm_default();
$this->fields['bool'] = new HTMLPurifier_Printer_ConfigForm_bool(); $this->fields[HTMLPurifier_VarParser::BOOL] = new HTMLPurifier_Printer_ConfigForm_bool();
} }
/** /**
@ -68,14 +71,23 @@ class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
/** /**
* Returns HTML output for a configuration form * Returns HTML output for a configuration form
* @param $config Configuration object of current form state * @param $config Configuration object of current form state, or an array
* where [0] has an HTML namespace and [1] is being rendered.
* @param $allowed Optional namespace(s) and directives to restrict form to. * @param $allowed Optional namespace(s) and directives to restrict form to.
*/ */
public function render($config, $allowed = true, $render_controls = true) { public function render($config, $allowed = true, $render_controls = true) {
$this->config = $config; if (is_array($config) && isset($config[0])) {
$this->prepareGenerator($config); $gen_config = $config[0];
$config = $config[1];
} else {
$gen_config = $config;
}
$allowed = HTMLPurifier_Config::getAllowedDirectivesForForm($allowed); $this->config = $config;
$this->genConfig = $gen_config;
$this->prepareGenerator($gen_config);
$allowed = HTMLPurifier_Config::getAllowedDirectivesForForm($allowed, $config->def);
$all = array(); $all = array();
foreach ($allowed as $key) { foreach ($allowed as $key) {
list($ns, $directive) = $key; list($ns, $directive) = $key;
@ -148,13 +160,19 @@ class HTMLPurifier_Printer_ConfigForm extends HTMLPurifier_Printer
$ret .= $this->start('td'); $ret .= $this->start('td');
$def = $this->config->def->info[$ns][$directive]; $def = $this->config->def->info[$ns][$directive];
$type = $def->type; if (is_int($def)) {
if (!isset($this->fields[$type])) $type = 'default'; $allow_null = $def < 0;
$type = abs($def);
} else {
$type = $def->type;
$allow_null = isset($def->allow_null);
}
if (!isset($this->fields[$type])) $type = 0; // default
$type_obj = $this->fields[$type]; $type_obj = $this->fields[$type];
if ($def->allow_null) { if ($allow_null) {
$type_obj = new HTMLPurifier_Printer_ConfigForm_NullDecorator($type_obj); $type_obj = new HTMLPurifier_Printer_ConfigForm_NullDecorator($type_obj);
} }
$ret .= $type_obj->render($ns, $directive, $value, $this->name, $this->config); $ret .= $type_obj->render($ns, $directive, $value, $this->name, array($this->genConfig, $this->config));
$ret .= $this->end('td'); $ret .= $this->end('td');
$ret .= $this->end('tr'); $ret .= $this->end('tr');
} }
@ -180,7 +198,14 @@ class HTMLPurifier_Printer_ConfigForm_NullDecorator extends HTMLPurifier_Printer
$this->obj = $obj; $this->obj = $obj;
} }
public function render($ns, $directive, $value, $name, $config) { public function render($ns, $directive, $value, $name, $config) {
$this->prepareGenerator($config); if (is_array($config) && isset($config[0])) {
$gen_config = $config[0];
$config = $config[1];
} else {
$gen_config = $config;
}
$this->prepareGenerator($gen_config);
$ret = ''; $ret = '';
$ret .= $this->start('label', array('for' => "$name:Null_$ns.$directive")); $ret .= $this->start('label', array('for' => "$name:Null_$ns.$directive"));
$ret .= $this->element('span', "$ns.$directive:", array('class' => 'verbose')); $ret .= $this->element('span', "$ns.$directive:", array('class' => 'verbose'));
@ -202,7 +227,7 @@ class HTMLPurifier_Printer_ConfigForm_NullDecorator extends HTMLPurifier_Printer
$ret .= $this->elementEmpty('input', $attr); $ret .= $this->elementEmpty('input', $attr);
$ret .= $this->text(' or '); $ret .= $this->text(' or ');
$ret .= $this->elementEmpty('br'); $ret .= $this->elementEmpty('br');
$ret .= $this->obj->render($ns, $directive, $value, $name, $config); $ret .= $this->obj->render($ns, $directive, $value, $name, array($gen_config, $config));
return $ret; return $ret;
} }
} }
@ -214,22 +239,33 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
public $cols = 18; public $cols = 18;
public $rows = 5; public $rows = 5;
public function render($ns, $directive, $value, $name, $config) { public function render($ns, $directive, $value, $name, $config) {
$this->prepareGenerator($config); if (is_array($config) && isset($config[0])) {
$gen_config = $config[0];
$config = $config[1];
} else {
$gen_config = $config;
}
$this->prepareGenerator($gen_config);
// this should probably be split up a little // this should probably be split up a little
$ret = ''; $ret = '';
$def = $config->def->info[$ns][$directive]; $def = $config->def->info[$ns][$directive];
if (is_int($def)) {
$type = abs($def);
} else {
$type = $def->type;
}
if (is_array($value)) { if (is_array($value)) {
switch ($def->type) { switch ($type) {
case 'lookup': case HTMLPurifier_VarParser::LOOKUP:
$array = $value; $array = $value;
$value = array(); $value = array();
foreach ($array as $val => $b) { foreach ($array as $val => $b) {
$value[] = $val; $value[] = $val;
} }
case 'list': case HTMLPurifier_VarParser::ALIST:
$value = implode(PHP_EOL, $value); $value = implode(PHP_EOL, $value);
break; break;
case 'hash': case HTMLPurifier_VarParser::HASH:
$nvalue = ''; $nvalue = '';
foreach ($value as $i => $v) { foreach ($value as $i => $v) {
$nvalue .= "$i:$v" . PHP_EOL; $nvalue .= "$i:$v" . PHP_EOL;
@ -240,7 +276,7 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
$value = ''; $value = '';
} }
} }
if ($def->type === 'mixed') { if ($type === HTMLPurifier_VarParser::MIXED) {
return 'Not supported'; return 'Not supported';
$value = serialize($value); $value = serialize($value);
} }
@ -249,7 +285,7 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
'id' => "$name:$ns.$directive" 'id' => "$name:$ns.$directive"
); );
if ($value === null) $attr['disabled'] = 'disabled'; if ($value === null) $attr['disabled'] = 'disabled';
if (is_array($def->allowed)) { if (isset($def->allowed)) {
$ret .= $this->start('select', $attr); $ret .= $this->start('select', $attr);
foreach ($def->allowed as $val => $b) { foreach ($def->allowed as $val => $b) {
$attr = array(); $attr = array();
@ -258,8 +294,11 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
} }
$ret .= $this->end('select'); $ret .= $this->end('select');
} elseif ( } elseif (
$def->type == 'text' || $def->type == 'itext' || $type === HTMLPurifier_VarParser::TEXT ||
$def->type == 'list' || $def->type == 'hash' || $def->type == 'lookup' $type === HTMLPurifier_VarParser::ITEXT ||
$type === HTMLPurifier_VarParser::ALIST ||
$type === HTMLPurifier_VarParser::HASH ||
$type === HTMLPurifier_VarParser::LOOKUP
) { ) {
$attr['cols'] = $this->cols; $attr['cols'] = $this->cols;
$attr['rows'] = $this->rows; $attr['rows'] = $this->rows;
@ -280,7 +319,13 @@ class HTMLPurifier_Printer_ConfigForm_default extends HTMLPurifier_Printer {
*/ */
class HTMLPurifier_Printer_ConfigForm_bool extends HTMLPurifier_Printer { class HTMLPurifier_Printer_ConfigForm_bool extends HTMLPurifier_Printer {
public function render($ns, $directive, $value, $name, $config) { public function render($ns, $directive, $value, $name, $config) {
$this->prepareGenerator($config); if (is_array($config) && isset($config[0])) {
$gen_config = $config[0];
$config = $config[1];
} else {
$gen_config = $config;
}
$this->prepareGenerator($gen_config);
$ret = ''; $ret = '';
$ret .= $this->start('div', array('id' => "$name:$ns.$directive")); $ret .= $this->start('div', array('id' => "$name:$ns.$directive"));

View File

@ -18,7 +18,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
// local variables // local variables
$result = array(); $result = array();
$generator = new HTMLPurifier_Generator(); $generator = new HTMLPurifier_Generator($config, $context);
$escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags'); $escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags');
$e = $context->get('ErrorCollector', true); $e = $context->get('ErrorCollector', true);
@ -169,7 +169,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
if ($escape_invalid_tags) { if ($escape_invalid_tags) {
if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag to text'); if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag to text');
$result[] = new HTMLPurifier_Token_Text( $result[] = new HTMLPurifier_Token_Text(
$generator->generateFromToken($token, $config, $context) $generator->generateFromToken($token)
); );
} elseif ($e) { } elseif ($e) {
$e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag removed'); $e->send(E_WARNING, 'Strategy_MakeWellFormed: Unnecessary end tag removed');
@ -209,7 +209,7 @@ class HTMLPurifier_Strategy_MakeWellFormed extends HTMLPurifier_Strategy
if ($skipped_tags === false) { if ($skipped_tags === false) {
if ($escape_invalid_tags) { if ($escape_invalid_tags) {
$result[] = new HTMLPurifier_Token_Text( $result[] = new HTMLPurifier_Token_Text(
$generator->generateFromToken($token, $config, $context) $generator->generateFromToken($token)
); );
if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Stray end tag to text'); if ($e) $e->send(E_WARNING, 'Strategy_MakeWellFormed: Stray end tag to text');
} elseif ($e) { } elseif ($e) {

View File

@ -13,7 +13,7 @@ class HTMLPurifier_Strategy_RemoveForeignElements extends HTMLPurifier_Strategy
public function execute($tokens, $config, $context) { public function execute($tokens, $config, $context) {
$definition = $config->getHTMLDefinition(); $definition = $config->getHTMLDefinition();
$generator = new HTMLPurifier_Generator(); $generator = new HTMLPurifier_Generator($config, $context);
$result = array(); $result = array();
$escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags'); $escape_invalid_tags = $config->get('Core', 'EscapeInvalidTags');
@ -101,7 +101,7 @@ class HTMLPurifier_Strategy_RemoveForeignElements extends HTMLPurifier_Strategy
// invalid tag, generate HTML representation and insert in // invalid tag, generate HTML representation and insert in
if ($e) $e->send(E_WARNING, 'Strategy_RemoveForeignElements: Foreign element to text'); if ($e) $e->send(E_WARNING, 'Strategy_RemoveForeignElements: Foreign element to text');
$token = new HTMLPurifier_Token_Text( $token = new HTMLPurifier_Token_Text(
$generator->generateFromToken($token, $config, $context) $generator->generateFromToken($token)
); );
} else { } else {
// check if we need to destroy all of the tag's children // check if we need to destroy all of the tag's children

View File

@ -58,11 +58,10 @@ style="float:right;">
$schema_builder = new HTMLPurifier_ConfigSchema_Builder_ConfigSchema(); $schema_builder = new HTMLPurifier_ConfigSchema_Builder_ConfigSchema();
$schema = $schema_builder->build($interchange); $schema = $schema_builder->build($interchange);
HTMLPurifier_ConfigSchema::instance($schema);
$config = HTMLPurifier_Config::loadArrayFromForm($_GET, 'config'); $config = HTMLPurifier_Config::loadArrayFromForm($_GET, 'config', true, true, $schema);
$printer = new HTMLPurifier_Printer_ConfigForm('config', '?doc#%s'); $printer = new HTMLPurifier_Printer_ConfigForm('config', '?doc#%s');
echo $printer->render($config); echo $printer->render(array(HTMLPurifier_Config::createDefault(), $config));
?> ?>
</form> </form>

View File

@ -13,8 +13,11 @@ if (file_exists('printDefinition.settings.php')) {
include 'printDefinition.settings.php'; include 'printDefinition.settings.php';
} }
$gen_config = HTMLPurifier_Config::createDefault();
$printer_html_definition = new HTMLPurifier_Printer_HTMLDefinition(); $printer_html_definition = new HTMLPurifier_Printer_HTMLDefinition();
$printer_html_definition->prepareGenerator($gen_config);
$printer_css_definition = new HTMLPurifier_Printer_CSSDefinition(); $printer_css_definition = new HTMLPurifier_Printer_CSSDefinition();
$printer_css_definition->prepareGenerator($gen_config);
$printer_config_form = new HTMLPurifier_Printer_ConfigForm( $printer_config_form = new HTMLPurifier_Printer_ConfigForm(
'config', 'config',

View File

@ -6,6 +6,7 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
public function setup() { public function setup() {
generate_mock_once('HTMLPurifier_Language'); generate_mock_once('HTMLPurifier_Language');
generate_mock_once('HTMLPurifier_Generator'); generate_mock_once('HTMLPurifier_Generator');
parent::setup();
} }
function test() { function test() {
@ -20,14 +21,13 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
$line = false; $line = false;
$context = new HTMLPurifier_Context(); $this->context->register('Locale', $language);
$context->register('Locale', $language); $this->context->register('CurrentLine', $line);
$context->register('CurrentLine', $line);
$generator = new HTMLPurifier_Generator(); $generator = new HTMLPurifier_Generator($this->config, $this->context);
$context->register('Generator', $generator); $this->context->register('Generator', $generator);
$collector = new HTMLPurifier_ErrorCollector($context); $collector = new HTMLPurifier_ErrorCollector($this->context);
$line = 23; $line = 23;
$collector->send(E_ERROR, 'message-1'); $collector->send(E_ERROR, 'message-1');
@ -48,23 +48,21 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
$config = HTMLPurifier_Config::create(array('Core.MaintainLineNumbers' => true)); $config = HTMLPurifier_Config::create(array('Core.MaintainLineNumbers' => true));
$this->assertIdentical($collector->getHTMLFormatted($config), $formatted_result); $this->assertIdentical($collector->getHTMLFormatted($this->config), $formatted_result);
} }
function testNoErrors() { function testNoErrors() {
$language = new HTMLPurifier_LanguageMock(); $language = new HTMLPurifier_LanguageMock();
$language->setReturnValue('getMessage', 'No errors', array('ErrorCollector: No errors')); $language->setReturnValue('getMessage', 'No errors', array('ErrorCollector: No errors'));
$context = new HTMLPurifier_Context(); $this->context->register('Locale', $language);
$context->register('Locale', $language);
$generator = new HTMLPurifier_Generator(); $generator = new HTMLPurifier_Generator($this->config, $this->context);
$context->register('Generator', $generator); $this->context->register('Generator', $generator);
$collector = new HTMLPurifier_ErrorCollector($context); $collector = new HTMLPurifier_ErrorCollector($this->context);
$formatted_result = '<p>No errors</p>'; $formatted_result = '<p>No errors</p>';
$config = HTMLPurifier_Config::createDefault(); $this->assertIdentical($collector->getHTMLFormatted($this->config), $formatted_result);
$this->assertIdentical($collector->getHTMLFormatted($config), $formatted_result);
} }
function testNoLineNumbers() { function testNoLineNumbers() {
@ -72,13 +70,12 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
$language->setReturnValue('getMessage', 'Message 1', array('message-1')); $language->setReturnValue('getMessage', 'Message 1', array('message-1'));
$language->setReturnValue('getMessage', 'Message 2', array('message-2')); $language->setReturnValue('getMessage', 'Message 2', array('message-2'));
$language->setReturnValue('getErrorName', 'Error', array(E_ERROR)); $language->setReturnValue('getErrorName', 'Error', array(E_ERROR));
$context = new HTMLPurifier_Context(); $this->context->register('Locale', $language);
$context->register('Locale', $language);
$generator = new HTMLPurifier_Generator(); $generator = new HTMLPurifier_Generator($this->config, $this->context);
$context->register('Generator', $generator); $this->context->register('Generator', $generator);
$collector = new HTMLPurifier_ErrorCollector($context); $collector = new HTMLPurifier_ErrorCollector($this->context);
$collector->send(E_ERROR, 'message-1'); $collector->send(E_ERROR, 'message-1');
$collector->send(E_ERROR, 'message-2'); $collector->send(E_ERROR, 'message-2');
@ -91,23 +88,21 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
$formatted_result = $formatted_result =
'<ul><li><strong>Error</strong>: Message 1</li>'. '<ul><li><strong>Error</strong>: Message 1</li>'.
'<li><strong>Error</strong>: Message 2</li></ul>'; '<li><strong>Error</strong>: Message 2</li></ul>';
$config = HTMLPurifier_Config::createDefault(); $this->assertIdentical($collector->getHTMLFormatted($this->config), $formatted_result);
$this->assertIdentical($collector->getHTMLFormatted($config), $formatted_result);
} }
function testContextSubstitutions() { function testContextSubstitutions() {
$language = new HTMLPurifier_LanguageMock(); $language = new HTMLPurifier_LanguageMock();
$context = new HTMLPurifier_Context(); $this->context->register('Locale', $language);
$context->register('Locale', $language);
$generator = new HTMLPurifier_Generator(); $generator = new HTMLPurifier_Generator($this->config, $this->context);
$context->register('Generator', $generator); $this->context->register('Generator', $generator);
$current_token = false; $current_token = false;
$context->register('CurrentToken', $current_token); $this->context->register('CurrentToken', $current_token);
$collector = new HTMLPurifier_ErrorCollector($context); $collector = new HTMLPurifier_ErrorCollector($this->context);
// 0 // 0
$current_token = new HTMLPurifier_Token_Start('a', array('href' => 'http://example.com'), 32); $current_token = new HTMLPurifier_Token_Start('a', array('href' => 'http://example.com'), 32);
@ -123,7 +118,7 @@ class HTMLPurifier_ErrorCollectorTest extends HTMLPurifier_Harness
$collector->send(E_NOTICE, 'message-attr'); // test when context isn't available $collector->send(E_NOTICE, 'message-attr'); // test when context isn't available
// 2 // 2
$context->register('CurrentAttr', $current_attr); $this->context->register('CurrentAttr', $current_attr);
$collector->send(E_NOTICE, 'message-attr'); $collector->send(E_NOTICE, 'message-attr');
$result = array( $result = array(

View File

@ -37,7 +37,7 @@ class HTMLPurifier_LanguageTest extends HTMLPurifier_Harness
function test_formatMessage_tokenParameter() { function test_formatMessage_tokenParameter() {
$config = HTMLPurifier_Config::createDefault(); $config = HTMLPurifier_Config::createDefault();
$context = new HTMLPurifier_Context(); $context = new HTMLPurifier_Context();
$generator = new HTMLPurifier_Generator(); // replace with mock if this gets icky $generator = new HTMLPurifier_Generator($config, $context); // replace with mock if this gets icky
$context->register('Generator', $generator); $context->register('Generator', $generator);
$lang = new HTMLPurifier_Language($config, $context); $lang = new HTMLPurifier_Language($config, $context);
$lang->_loaded = true; $lang->_loaded = true;