mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2024-11-14 01:08:41 +00:00
609977f9f5
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@106 48356398-32a2-884e-a903-53898d9a118a
93 lines
3.0 KiB
PHP
93 lines
3.0 KiB
PHP
<?php
|
|
|
|
require_once 'HTMLPurifier/Lexer/DirectLex.php';
|
|
|
|
class HTMLPurifier_Lexer_DirectLexTest extends UnitTestCase
|
|
{
|
|
|
|
var $DirectLex;
|
|
|
|
function setUp() {
|
|
$this->DirectLex = new HTMLPurifier_Lexer_DirectLex();
|
|
}
|
|
|
|
function test_specialEntityCallback() {
|
|
$HP =& $this->DirectLex;
|
|
|
|
$this->assertIdentical("'",$HP->specialEntityCallback(
|
|
array(''', null, '39', null) ));
|
|
}
|
|
|
|
function test_parseData() {
|
|
$HP =& $this->DirectLex;
|
|
|
|
$this->assertIdentical('asdf', $HP->parseData('asdf'));
|
|
$this->assertIdentical('&', $HP->parseData('&'));
|
|
$this->assertIdentical('"', $HP->parseData('"'));
|
|
$this->assertIdentical("'", $HP->parseData('''));
|
|
$this->assertIdentical("'", $HP->parseData('''));
|
|
$this->assertIdentical('&&&', $HP->parseData('&&&'));
|
|
$this->assertIdentical('&&', $HP->parseData('&&')); // [INVALID]
|
|
$this->assertIdentical('Procter & Gamble',
|
|
$HP->parseData('Procter & Gamble')); // [INVALID]
|
|
|
|
// This is not special, thus not converted. Test of fault tolerance,
|
|
// realistically speaking, this should never happen
|
|
$this->assertIdentical('-', $HP->parseData('-'));
|
|
}
|
|
|
|
// internals testing
|
|
function test_parseAttributeString() {
|
|
|
|
$input[0] = 'href="about:blank" rel="nofollow"';
|
|
$expect[0] = array('href'=>'about:blank', 'rel'=>'nofollow');
|
|
|
|
$input[1] = "href='about:blank'";
|
|
$expect[1] = array('href'=>'about:blank');
|
|
|
|
// note that the single quotes aren't /really/ escaped
|
|
$input[2] = 'onclick="javascript:alert(\'asdf\');"';
|
|
$expect[2] = array('onclick' => "javascript:alert('asdf');");
|
|
|
|
$input[3] = 'selected';
|
|
$expect[3] = array('selected'=>'selected');
|
|
|
|
// [INVALID]
|
|
$input[4] = '="nokey"';
|
|
$expect[4] = array();
|
|
|
|
// [SIMPLE]
|
|
$input[5] = 'color=blue';
|
|
$expect[5] = array('color' => 'blue');
|
|
|
|
// [INVALID]
|
|
$input[6] = 'href="about:blank';
|
|
$expect[6] = array('href' => 'about:blank');
|
|
|
|
// [INVALID]
|
|
$input[7] = '"=';
|
|
$expect[7] = array('"' => '');
|
|
// we ought to get array()
|
|
|
|
$input[8] = 'href ="about:blank"rel ="nofollow"';
|
|
$expect[8] = array('href' => 'about:blank', 'rel' => 'nofollow');
|
|
|
|
$input[9] = 'two bool';
|
|
$expect[9] = array('two' => 'two', 'bool' => 'bool');
|
|
|
|
$input[10] = 'name="input" selected';
|
|
$expect[10] = array('name' => 'input', 'selected' => 'selected');
|
|
|
|
$size = count($input);
|
|
for($i = 0; $i < $size; $i++) {
|
|
$result = $this->DirectLex->parseAttributeString($input[$i]);
|
|
$this->assertEqual($expect[$i], $result, 'Test ' . $i . ': %s');
|
|
paintIf($result, $expect[$i] != $result);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
?>
|