mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-05 06:01:52 +00:00
[1.6.1] Implement clear in br and align in caption, table, img and hr
- Refactored ValidateAttributesTest.php git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1018 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
fd35c43643
commit
a01459c87a
2
NEWS
2
NEWS
@ -21,6 +21,8 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
|
|||||||
+ hspace and vspace in img
|
+ hspace and vspace in img
|
||||||
+ size and noshade in hr
|
+ size and noshade in hr
|
||||||
+ nowrap in td
|
+ nowrap in td
|
||||||
|
+ clear in br
|
||||||
|
+ align in caption, table, img and hr
|
||||||
! target attribute in a tag supported, use %Attr.AllowedFrameTargets
|
! target attribute in a tag supported, use %Attr.AllowedFrameTargets
|
||||||
to enable
|
to enable
|
||||||
! CSS property white-space now allows nowrap (supported in all modern
|
! CSS property white-space now allows nowrap (supported in all modern
|
||||||
|
5
TODO
5
TODO
@ -7,11 +7,6 @@ TODO List
|
|||||||
? Maybe I'll Do It
|
? Maybe I'll Do It
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
1.6.1 [Oh Dear, We Missed Something!]
|
|
||||||
# align in img, table, hr and caption
|
|
||||||
# clear in br
|
|
||||||
# type in ul, ol, li
|
|
||||||
|
|
||||||
1.7 release [Advanced API]
|
1.7 release [Advanced API]
|
||||||
# Complete advanced API, and fully document it
|
# Complete advanced API, and fully document it
|
||||||
# Implement all edge-case attribute transforms
|
# Implement all edge-case attribute transforms
|
||||||
|
@ -263,17 +263,17 @@ Mozilla on inside and needs -moz-outline, no IE support.</td></tr>
|
|||||||
|
|
||||||
<tbody>
|
<tbody>
|
||||||
<tr><th colspan="3">Transform, target milestone 1.6.1/1.7</th></tr>
|
<tr><th colspan="3">Transform, target milestone 1.6.1/1.7</th></tr>
|
||||||
<tr><td rowspan="5">align</td><td>CAPTION</td><td>Near-equiv style 'caption-side', drop left and right</td></tr>
|
<tr class="impl-yes"><td rowspan="5">align</td><td>CAPTION</td><td>'caption-side' for top/bottom, 'text-align' for left/right</td></tr>
|
||||||
<tr><td>IMG</td><td rowspan="3">See specimens/html-align-to-css.html</td></tr>
|
<tr class="impl-yes"><td>IMG</td><td rowspan="3">See specimens/html-align-to-css.html</td></tr>
|
||||||
<tr><td>TABLE</td></tr>
|
<tr class="impl-yes"><td>TABLE</td></tr>
|
||||||
<tr><td>HR</td></tr>
|
<tr class="impl-yes"><td>HR</td></tr>
|
||||||
<tr class="impl-yes"><td>H1, H2, H3, H4, H5, H6, P</td><td>Equivalent style 'text-align'</td></tr>
|
<tr class="impl-yes"><td>H1, H2, H3, H4, H5, H6, P</td><td>Equivalent style 'text-align'</td></tr>
|
||||||
<tr class="required impl-yes"><td>alt</td><td>IMG</td><td>Required, insert image filename if src is present or default invalid image text</td></tr>
|
<tr class="required impl-yes"><td>alt</td><td>IMG</td><td>Required, insert image filename if src is present or default invalid image text</td></tr>
|
||||||
<tr class="impl-yes"><td rowspan="3">bgcolor</td><td>TABLE</td><td>Superset style 'background-color'</td></tr>
|
<tr class="impl-yes"><td rowspan="3">bgcolor</td><td>TABLE</td><td>Superset style 'background-color'</td></tr>
|
||||||
<tr class="impl-yes"><td>TR</td><td>Superset style 'background-color'</td></tr>
|
<tr class="impl-yes"><td>TR</td><td>Superset style 'background-color'</td></tr>
|
||||||
<tr class="impl-yes"><td>TD, TH</td><td>Superset style 'background-color'</td></tr>
|
<tr class="impl-yes"><td>TD, TH</td><td>Superset style 'background-color'</td></tr>
|
||||||
<tr class="impl-yes"><td>border</td><td>IMG</td><td>Equivalent style <code>border:[number]px solid</code></td></tr>
|
<tr class="impl-yes"><td>border</td><td>IMG</td><td>Equivalent style <code>border:[number]px solid</code></td></tr>
|
||||||
<tr><td>clear</td><td>BR</td><td>Near-equiv style 'clear', transform 'all' into 'both'</td></tr>
|
<tr class="impl-yes"><td>clear</td><td>BR</td><td>Near-equiv style 'clear', transform 'all' into 'both'</td></tr>
|
||||||
<tr class="impl-no"><td>compact</td><td>DL, OL, UL</td><td>Boolean, needs custom CSS class; rarely used anyway</td></tr>
|
<tr class="impl-no"><td>compact</td><td>DL, OL, UL</td><td>Boolean, needs custom CSS class; rarely used anyway</td></tr>
|
||||||
<tr class="required impl-yes"><td>dir</td><td>BDO</td><td>Required, insert ltr (or configuration value) if none</td></tr>
|
<tr class="required impl-yes"><td>dir</td><td>BDO</td><td>Required, insert ltr (or configuration value) if none</td></tr>
|
||||||
<tr class="impl-yes"><td>height</td><td>TD, TH</td><td>Near-equiv style 'height', needs px suffix if original was in pixels</td></tr>
|
<tr class="impl-yes"><td>height</td><td>TD, TH</td><td>Near-equiv style 'height', needs px suffix if original was in pixels</td></tr>
|
||||||
|
@ -27,7 +27,8 @@ class HTMLPurifier_HTMLModule_TransformToStrict extends HTMLPurifier_HTMLModule
|
|||||||
|
|
||||||
// we're actually modifying these elements, not defining them
|
// we're actually modifying these elements, not defining them
|
||||||
var $elements = array('h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'p',
|
var $elements = array('h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'p',
|
||||||
'blockquote', 'table', 'td', 'th', 'tr', 'img', 'a', 'hr');
|
'blockquote', 'table', 'td', 'th', 'tr', 'img', 'a', 'hr', 'br',
|
||||||
|
'caption');
|
||||||
|
|
||||||
var $info_tag_transform = array(
|
var $info_tag_transform = array(
|
||||||
// placeholders, see constructor for definitions
|
// placeholders, see constructor for definitions
|
||||||
@ -110,6 +111,45 @@ class HTMLPurifier_HTMLModule_TransformToStrict extends HTMLPurifier_HTMLModule
|
|||||||
$this->info['hr']->attr_transform_pre['size'] = new HTMLPurifier_AttrTransform_Length('size', 'height');
|
$this->info['hr']->attr_transform_pre['size'] = new HTMLPurifier_AttrTransform_Length('size', 'height');
|
||||||
$this->info['hr']->attr_transform_pre['noshade'] = new HTMLPurifier_AttrTransform_BoolToCSS('noshade', 'border-style:solid;');
|
$this->info['hr']->attr_transform_pre['noshade'] = new HTMLPurifier_AttrTransform_BoolToCSS('noshade', 'border-style:solid;');
|
||||||
|
|
||||||
|
$this->info['br']->attr_transform_pre['clear'] =
|
||||||
|
new HTMLPurifier_AttrTransform_EnumToCSS('clear', array(
|
||||||
|
'left' => 'clear:left;',
|
||||||
|
'right' => 'clear:right;',
|
||||||
|
'all' => 'clear:both;',
|
||||||
|
'none' => 'clear:none;',
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->info['caption']->attr_transform_pre['align'] =
|
||||||
|
new HTMLPurifier_AttrTransform_EnumToCSS('align', array(
|
||||||
|
'left' => 'text-align:left;',
|
||||||
|
'right' => 'text-align:right;',
|
||||||
|
'top' => 'caption-side:top;',
|
||||||
|
'bottom' => 'caption-side:bottom;'
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->info['table']->attr_transform_pre['align'] =
|
||||||
|
new HTMLPurifier_AttrTransform_EnumToCSS('align', array(
|
||||||
|
'left' => 'float:left;',
|
||||||
|
'center' => 'margin-left:auto;margin-right:auto;',
|
||||||
|
'right' => 'float:right;'
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->info['img']->attr_transform_pre['align'] =
|
||||||
|
new HTMLPurifier_AttrTransform_EnumToCSS('align', array(
|
||||||
|
'left' => 'float:left;',
|
||||||
|
'right' => 'float:right;',
|
||||||
|
'top' => 'vertical-align:top;',
|
||||||
|
'middle' => 'vertical-align:middle;',
|
||||||
|
'bottom' => 'vertical-align:baseline;',
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->info['hr']->attr_transform_pre['align'] =
|
||||||
|
new HTMLPurifier_AttrTransform_EnumToCSS('align', array(
|
||||||
|
'left' => 'margin-left:0;margin-right:auto;text-align:left;',
|
||||||
|
'center' => 'margin-left:auto;margin-right:auto;text-align:center;',
|
||||||
|
'right' => 'margin-left:auto;margin-right:0;text-align:right;'
|
||||||
|
));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var $defines_child_def = true;
|
var $defines_child_def = true;
|
||||||
|
@ -13,14 +13,11 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
$this->obj = new HTMLPurifier_Strategy_ValidateAttributes();
|
$this->obj = new HTMLPurifier_Strategy_ValidateAttributes();
|
||||||
}
|
}
|
||||||
|
|
||||||
function test() {
|
function testEmpty() {
|
||||||
|
|
||||||
// attribute order is VERY fragile, perhaps we should define
|
|
||||||
// an ordering scheme!
|
|
||||||
|
|
||||||
$this->assertResult('');
|
$this->assertResult('');
|
||||||
|
}
|
||||||
|
|
||||||
// test ids
|
function testIDs() {
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<div id="valid">Kill the ID.</div>',
|
'<div id="valid">Kill the ID.</div>',
|
||||||
'<div>Kill the ID.</div>'
|
'<div>Kill the ID.</div>'
|
||||||
@ -71,26 +68,44 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
// test classes
|
// name rewritten as id
|
||||||
|
$this->assertResult(
|
||||||
|
'<a name="foobar" />',
|
||||||
|
'<a id="foobar" />',
|
||||||
|
array('HTML.EnableAttrID' => true)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testClasses() {
|
||||||
$this->assertResult('<div class="valid">Valid</div>');
|
$this->assertResult('<div class="valid">Valid</div>');
|
||||||
|
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<div class="valid 0invalid">Keep valid.</div>',
|
'<div class="valid 0invalid">Keep valid.</div>',
|
||||||
'<div class="valid">Keep valid.</div>'
|
'<div class="valid">Keep valid.</div>'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// test title
|
function testTitle() {
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<acronym title="PHP: Hypertext Preprocessor">PHP</acronym>'
|
'<acronym title="PHP: Hypertext Preprocessor">PHP</acronym>'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// test lang
|
function testLang() {
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<span lang="fr">La soupe.</span>',
|
'<span lang="fr">La soupe.</span>',
|
||||||
'<span lang="fr" xml:lang="fr">La soupe.</span>'
|
'<span lang="fr" xml:lang="fr">La soupe.</span>'
|
||||||
);
|
);
|
||||||
|
|
||||||
// test align
|
// test only xml:lang for XHTML 1.1
|
||||||
|
$this->assertResult(
|
||||||
|
'<b lang="en">asdf</b>',
|
||||||
|
'<b xml:lang="en">asdf</b>', array('HTML.Doctype' => 'XHTML 1.1')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testAlign() {
|
||||||
|
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<h1 align="center">Centered Headline</h1>',
|
'<h1 align="center">Centered Headline</h1>',
|
||||||
'<h1 style="text-align:center;">Centered Headline</h1>'
|
'<h1 style="text-align:center;">Centered Headline</h1>'
|
||||||
@ -112,7 +127,9 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
'<h1>Invalid Headline</h1>'
|
'<h1>Invalid Headline</h1>'
|
||||||
);
|
);
|
||||||
|
|
||||||
// test table
|
}
|
||||||
|
|
||||||
|
function testTable() {
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<table frame="above" rules="rows" summary="A test table" border="2" cellpadding="5%" cellspacing="3" width="100%">
|
'<table frame="above" rules="rows" summary="A test table" border="2" cellpadding="5%" cellspacing="3" width="100%">
|
||||||
<col align="right" width="4*" />
|
<col align="right" width="4*" />
|
||||||
@ -131,7 +148,64 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
</table>'
|
</table>'
|
||||||
);
|
);
|
||||||
|
|
||||||
// test URI
|
// test col.span is non-zero
|
||||||
|
$this->assertResult(
|
||||||
|
'<col span="0" />',
|
||||||
|
'<col />'
|
||||||
|
);
|
||||||
|
// lengths
|
||||||
|
$this->assertResult(
|
||||||
|
'<td height="10" width="5%" /><th height="5%" width="10" /><hr width="10" height="10" />',
|
||||||
|
'<td style="height:10px;width:5%;" /><th style="height:5%;width:10px;" /><hr style="width:10px;" />'
|
||||||
|
);
|
||||||
|
// td boolean transformation
|
||||||
|
$this->assertResult(
|
||||||
|
'<td nowrap />',
|
||||||
|
'<td style="white-space:nowrap;" />'
|
||||||
|
);
|
||||||
|
|
||||||
|
// caption align transformation
|
||||||
|
$this->assertResult(
|
||||||
|
'<caption align="left" />',
|
||||||
|
'<caption style="text-align:left;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<caption align="right" />',
|
||||||
|
'<caption style="text-align:right;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<caption align="top" />',
|
||||||
|
'<caption style="caption-side:top;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<caption align="bottom" />',
|
||||||
|
'<caption style="caption-side:bottom;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<caption align="nonsense" />',
|
||||||
|
'<caption />'
|
||||||
|
);
|
||||||
|
|
||||||
|
// align transformation
|
||||||
|
$this->assertResult(
|
||||||
|
'<table align="left" />',
|
||||||
|
'<table style="float:left;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<table align="center" />',
|
||||||
|
'<table style="margin-left:auto;margin-right:auto;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<table align="right" />',
|
||||||
|
'<table style="float:right;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<table align="top" />',
|
||||||
|
'<table />'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testURI() {
|
||||||
$this->assertResult('<a href="http://www.google.com/">Google</a>');
|
$this->assertResult('<a href="http://www.google.com/">Google</a>');
|
||||||
|
|
||||||
// test invalid URI
|
// test invalid URI
|
||||||
@ -139,9 +213,9 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
'<a href="javascript:badstuff();">Google</a>',
|
'<a href="javascript:badstuff();">Google</a>',
|
||||||
'<a>Google</a>'
|
'<a>Google</a>'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// test required attributes for img
|
function testImg() {
|
||||||
|
|
||||||
// (this should never happen, as RemoveForeignElements
|
// (this should never happen, as RemoveForeignElements
|
||||||
// should have removed the offending image tag)
|
// should have removed the offending image tag)
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
@ -158,7 +232,40 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
'<img alt="pretty picture" />',
|
'<img alt="pretty picture" />',
|
||||||
'<img alt="pretty picture" src="" />'
|
'<img alt="pretty picture" src="" />'
|
||||||
);
|
);
|
||||||
|
// mailto in image is not allowed
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="mailto:foo@example.com" />',
|
||||||
|
'<img src="" alt="Invalid image" />'
|
||||||
|
);
|
||||||
|
// align transformation
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foobar.jpg" alt="foobar" align="left" />',
|
||||||
|
'<img src="foobar.jpg" alt="foobar" style="float:left;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foobar.jpg" alt="foobar" align="right" />',
|
||||||
|
'<img src="foobar.jpg" alt="foobar" style="float:right;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foobar.jpg" alt="foobar" align="bottom" />',
|
||||||
|
'<img src="foobar.jpg" alt="foobar" style="vertical-align:baseline;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foobar.jpg" alt="foobar" align="middle" />',
|
||||||
|
'<img src="foobar.jpg" alt="foobar" style="vertical-align:middle;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foobar.jpg" alt="foobar" align="top" />',
|
||||||
|
'<img src="foobar.jpg" alt="foobar" style="vertical-align:top;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foobar.jpg" alt="foobar" align="outerspace" />',
|
||||||
|
'<img src="foobar.jpg" alt="foobar" />'
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function testBdo() {
|
||||||
// test required attributes for bdo
|
// test required attributes for bdo
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<bdo>Go left.</bdo>',
|
'<bdo>Go left.</bdo>',
|
||||||
@ -169,52 +276,23 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
'<bdo dir="blahblah">Invalid value!</bdo>',
|
'<bdo dir="blahblah">Invalid value!</bdo>',
|
||||||
'<bdo dir="ltr">Invalid value!</bdo>'
|
'<bdo dir="ltr">Invalid value!</bdo>'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// see above, behavior is subtly different
|
function testDir() {
|
||||||
|
// see testBdo, behavior is subtly different
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<span dir="blahblah">Invalid value!</span>',
|
'<span dir="blahblah">Invalid value!</span>',
|
||||||
'<span>Invalid value!</span>'
|
'<span>Invalid value!</span>'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// test col.span is non-zero
|
function testLinks() {
|
||||||
$this->assertResult(
|
|
||||||
'<col span="0" />',
|
|
||||||
'<col />'
|
|
||||||
);
|
|
||||||
|
|
||||||
// mailto in image is not allowed
|
|
||||||
$this->assertResult(
|
|
||||||
'<img src="mailto:foo@example.com" />',
|
|
||||||
'<img src="" alt="Invalid image" />'
|
|
||||||
);
|
|
||||||
|
|
||||||
// name rewritten as id
|
|
||||||
$this->assertResult(
|
|
||||||
'<a name="foobar" />',
|
|
||||||
'<a id="foobar" />',
|
|
||||||
array('HTML.EnableAttrID' => true)
|
|
||||||
);
|
|
||||||
|
|
||||||
// lengths
|
|
||||||
$this->assertResult(
|
|
||||||
'<td height="10" width="5%" /><th height="5%" width="10" /><hr width="10" height="10" />',
|
|
||||||
'<td style="height:10px;width:5%;" /><th style="height:5%;width:10px;" /><hr style="width:10px;" />'
|
|
||||||
);
|
|
||||||
|
|
||||||
// link types
|
// link types
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<a href="foo" rel="nofollow" />',
|
'<a href="foo" rel="nofollow" />',
|
||||||
true,
|
true,
|
||||||
array('Attr.AllowedRel' => 'nofollow')
|
array('Attr.AllowedRel' => 'nofollow')
|
||||||
);
|
);
|
||||||
|
|
||||||
// border
|
|
||||||
$this->assertResult(
|
|
||||||
'<img src="foo" alt="foo" hspace="1" vspace="3" />',
|
|
||||||
'<img src="foo" alt="foo" style="margin-top:3px;margin-bottom:3px;margin-left:1px;margin-right:1px;" />',
|
|
||||||
array('Attr.AllowedRel' => 'nofollow')
|
|
||||||
);
|
|
||||||
|
|
||||||
// link targets
|
// link targets
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<a href="foo" target="_top" />',
|
'<a href="foo" target="_top" />',
|
||||||
@ -230,8 +308,18 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
'<a href="foo" />',
|
'<a href="foo" />',
|
||||||
array('Attr.AllowedFrameTargets' => '_top', 'HTML.Strict' => true)
|
array('Attr.AllowedFrameTargets' => '_top', 'HTML.Strict' => true)
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// hr rule transformations
|
function testBorder() {
|
||||||
|
// border
|
||||||
|
$this->assertResult(
|
||||||
|
'<img src="foo" alt="foo" hspace="1" vspace="3" />',
|
||||||
|
'<img src="foo" alt="foo" style="margin-top:3px;margin-bottom:3px;margin-left:1px;margin-right:1px;" />',
|
||||||
|
array('Attr.AllowedRel' => 'nofollow')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testHr() {
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<hr size="3" />',
|
'<hr size="3" />',
|
||||||
'<hr style="height:3px;" />'
|
'<hr style="height:3px;" />'
|
||||||
@ -240,21 +328,47 @@ class HTMLPurifier_Strategy_ValidateAttributesTest extends
|
|||||||
'<hr noshade />',
|
'<hr noshade />',
|
||||||
'<hr style="border-style:solid;" />'
|
'<hr style="border-style:solid;" />'
|
||||||
);
|
);
|
||||||
|
// align transformation
|
||||||
// td boolean transformation
|
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<td nowrap />',
|
'<hr align="left" />',
|
||||||
'<td style="white-space:nowrap;" />'
|
'<hr style="margin-left:0;margin-right:auto;text-align:left;" />'
|
||||||
);
|
);
|
||||||
|
|
||||||
// test only one lang
|
|
||||||
$this->assertResult(
|
$this->assertResult(
|
||||||
'<b lang="en">asdf</b>',
|
'<hr align="center" />',
|
||||||
'<b xml:lang="en">asdf</b>', array('HTML.Doctype' => 'XHTML 1.1')
|
'<hr style="margin-left:auto;margin-right:auto;text-align:center;" />'
|
||||||
);
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<hr align="right" />',
|
||||||
|
'<hr style="margin-left:auto;margin-right:0;text-align:right;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<hr align="bottom" />',
|
||||||
|
'<hr />'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testBr() {
|
||||||
|
// br clear transformation
|
||||||
|
$this->assertResult(
|
||||||
|
'<br clear="left" />',
|
||||||
|
'<br style="clear:left;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<br clear="right" />',
|
||||||
|
'<br style="clear:right;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult( // test both?
|
||||||
|
'<br clear="all" />',
|
||||||
|
'<br style="clear:both;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<br clear="none" />',
|
||||||
|
'<br style="clear:none;" />'
|
||||||
|
);
|
||||||
|
$this->assertResult(
|
||||||
|
'<br clear="foo" />',
|
||||||
|
'<br />'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user