mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-24 22:31:52 +00:00
3af6457801
- Support executing a single unit tests using __only prefix - Hook in Email classes to main code, even if they're unused git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1373 48356398-32a2-884e-a903-53898d9a118a
78 lines
2.2 KiB
PHP
78 lines
2.2 KiB
PHP
<?php
|
|
|
|
require_once 'HTMLPurifier/ChildDefHarness.php';
|
|
require_once 'HTMLPurifier/ChildDef/Required.php';
|
|
|
|
class HTMLPurifier_ChildDef_RequiredTest extends HTMLPurifier_ChildDefHarness
|
|
{
|
|
|
|
function testPrepareString() {
|
|
$def = new HTMLPurifier_ChildDef_Required('foobar | bang |gizmo');
|
|
$this->assertIdentical($def->elements,
|
|
array(
|
|
'foobar' => true
|
|
,'bang' => true
|
|
,'gizmo' => true
|
|
));
|
|
}
|
|
|
|
function testPrepareArray() {
|
|
$def = new HTMLPurifier_ChildDef_Required(array('href', 'src'));
|
|
$this->assertIdentical($def->elements,
|
|
array(
|
|
'href' => true
|
|
,'src' => true
|
|
));
|
|
}
|
|
|
|
function setUp() {
|
|
parent::setUp();
|
|
$this->obj = new HTMLPurifier_ChildDef_Required('dt | dd');
|
|
}
|
|
|
|
function testEmptyInput() {
|
|
$this->assertResult('', false);
|
|
}
|
|
|
|
function testRemoveIllegalTagsAndElements() {
|
|
$this->assertResult(
|
|
'<dt>Term</dt>Text in an illegal location'.
|
|
'<dd>Definition</dd><b>Illegal tag</b>',
|
|
'<dt>Term</dt><dd>Definition</dd>');
|
|
$this->assertResult('How do you do!', false);
|
|
}
|
|
|
|
function testIgnoreWhitespace() {
|
|
// whitespace shouldn't trigger it
|
|
$this->assertResult("\n<dd>Definition</dd> ");
|
|
}
|
|
|
|
function testPreserveWhitespaceAfterRemoval() {
|
|
$this->assertResult(
|
|
'<dd>Definition</dd> <b></b> ',
|
|
'<dd>Definition</dd> '
|
|
);
|
|
}
|
|
|
|
function testDeleteNodeIfOnlyWhitespace() {
|
|
$this->assertResult("\t ", false);
|
|
}
|
|
|
|
function testPCDATAAllowed() {
|
|
$this->obj = new HTMLPurifier_ChildDef_Required('#PCDATA | b');
|
|
$this->assertResult('Out <b>Bold text</b><img />', 'Out <b>Bold text</b>');
|
|
}
|
|
|
|
function testPCDATAAllowedWithEscaping() {
|
|
$this->obj = new HTMLPurifier_ChildDef_Required('#PCDATA | b');
|
|
$this->config->set('Core', 'EscapeInvalidChildren', true);
|
|
$this->assertResult(
|
|
'Out <b>Bold text</b><img />',
|
|
'Out <b>Bold text</b><img />'
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|