1
0
mirror of https://github.com/ezyang/htmlpurifier.git synced 2025-08-06 14:16:32 +02:00

Implement HTMLT tests, and migrate HTMLPurifierTest to this format.

HTMLT tests are a compact and easy-to-use way of making assertPurification
type tests. They take the format of:

--INI--
Ns.Directive = "directive value"
--HTML--
Input HTML
--EXPECT--
Expected HTML

Expect more features and migration to be coming soon.

Signed-off-by: Edward Z. Yang <edwardzyang@thewritingpot.com>
This commit is contained in:
Edward Z. Yang
2008-07-05 02:34:19 -04:00
parent 334ffac5b4
commit e05bd77344
28 changed files with 208 additions and 187 deletions

View File

@@ -0,0 +1,31 @@
<?php
class HTMLPurifier_HTMLT extends HTMLPurifier_Harness
{
protected $path;
public function __construct($path) {
$this->path = $path;
parent::__construct($path);
}
public function testHtmlt() {
$parser = new HTMLPurifier_StringHashParser();
$hash = $parser->parseFile($this->path); // assume parser normalizes to "\n"
if (isset($hash['SKIPIF'])) {
if (eval($hash['SKIPIF'])) return;
}
$this->config->set('Output', 'Newline', "\n");
if (isset($hash['INI'])) {
// there should be a more efficient way than writing another
// ini file every time... probably means building a parser for
// ini (check out the yaml implementation we saw somewhere else)
$ini_file = $this->path . '.ini';
file_put_contents($ini_file, $hash['INI']);
$this->config->loadIni($ini_file);
}
$expect = isset($hash['EXPECT']) ? $hash['EXPECT'] : $hash['HTML'];
$this->assertPurification(rtrim($hash['HTML']), rtrim($expect));
if (isset($hash['INI'])) unlink($ini_file);
}
}