CSSTest.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <?php
  2. class HTMLPurifier_AttrDef_CSSTest extends HTMLPurifier_AttrDefHarness
  3. {
  4. function setup() {
  5. parent::setup();
  6. $this->def = new HTMLPurifier_AttrDef_CSS();
  7. }
  8. function test() {
  9. // regular cases, singular
  10. $this->assertDef('text-align:right;');
  11. $this->assertDef('border-left-style:solid;');
  12. $this->assertDef('border-style:solid dotted;');
  13. $this->assertDef('clear:right;');
  14. $this->assertDef('float:left;');
  15. $this->assertDef('font-style:italic;');
  16. $this->assertDef('font-variant:small-caps;');
  17. $this->assertDef('font-weight:bold;');
  18. $this->assertDef('list-style-position:outside;');
  19. $this->assertDef('list-style-type:upper-roman;');
  20. $this->assertDef('list-style:upper-roman inside;');
  21. $this->assertDef('text-transform:capitalize;');
  22. $this->assertDef('background-color:rgb(0,0,255);');
  23. $this->assertDef('background-color:transparent;');
  24. $this->assertDef('background:#333 url("chess.png") repeat fixed 50% top;');
  25. $this->assertDef('color:#F00;');
  26. $this->assertDef('border-top-color:#F00;');
  27. $this->assertDef('border-color:#F00 #FF0;');
  28. $this->assertDef('border-top-width:thin;');
  29. $this->assertDef('border-top-width:12px;');
  30. $this->assertDef('border-width:5px 1px 4px 2px;');
  31. $this->assertDef('border-top-width:-12px;', false);
  32. $this->assertDef('letter-spacing:normal;');
  33. $this->assertDef('letter-spacing:2px;');
  34. $this->assertDef('word-spacing:normal;');
  35. $this->assertDef('word-spacing:3em;');
  36. $this->assertDef('font-size:200%;');
  37. $this->assertDef('font-size:larger;');
  38. $this->assertDef('font-size:12pt;');
  39. $this->assertDef('line-height:2;');
  40. $this->assertDef('line-height:2em;');
  41. $this->assertDef('line-height:20%;');
  42. $this->assertDef('line-height:normal;');
  43. $this->assertDef('line-height:-20%;', false);
  44. $this->assertDef('margin-left:5px;');
  45. $this->assertDef('margin-right:20%;');
  46. $this->assertDef('margin-top:auto;');
  47. $this->assertDef('margin:auto 5%;');
  48. $this->assertDef('padding-bottom:5px;');
  49. $this->assertDef('padding-top:20%;');
  50. $this->assertDef('padding:20% 10%;');
  51. $this->assertDef('padding-top:-20%;', false);
  52. $this->assertDef('text-indent:3em;');
  53. $this->assertDef('text-indent:5%;');
  54. $this->assertDef('text-indent:-3em;');
  55. $this->assertDef('width:50%;');
  56. $this->assertDef('width:50px;');
  57. $this->assertDef('width:auto;');
  58. $this->assertDef('width:-50px;', false);
  59. $this->assertDef('text-decoration:underline;');
  60. $this->assertDef('font-family:sans-serif;');
  61. $this->assertDef("font-family:Gill, 'Times New Roman', sans-serif;");
  62. $this->assertDef('font:12px serif;');
  63. $this->assertDef('border:1px solid #000;');
  64. $this->assertDef('border-bottom:2em double #FF00FA;');
  65. $this->assertDef('border-collapse:collapse;');
  66. $this->assertDef('border-collapse:separate;');
  67. $this->assertDef('caption-side:top;');
  68. $this->assertDef('vertical-align:middle;');
  69. $this->assertDef('vertical-align:12px;');
  70. $this->assertDef('vertical-align:50%;');
  71. $this->assertDef('table-layout:fixed;');
  72. $this->assertDef('list-style-image:url("nice.jpg");');
  73. $this->assertDef('list-style:disc url("nice.jpg") inside;');
  74. $this->assertDef('background-image:url("foo.jpg");');
  75. $this->assertDef('background-image:none;');
  76. $this->assertDef('background-repeat:repeat-y;');
  77. $this->assertDef('background-attachment:fixed;');
  78. $this->assertDef('background-position:left 90%;');
  79. $this->assertDef('border-spacing:1em;');
  80. $this->assertDef('border-spacing:1em 2em;');
  81. // duplicates
  82. $this->assertDef('text-align:right;text-align:left;',
  83. 'text-align:left;');
  84. // a few composites
  85. $this->assertDef('font-variant:small-caps;font-weight:900;');
  86. $this->assertDef('float:right;text-align:right;');
  87. // selective removal
  88. $this->assertDef('text-transform:capitalize;destroy:it;',
  89. 'text-transform:capitalize;');
  90. // inherit works for everything
  91. $this->assertDef('text-align:inherit;');
  92. // bad props
  93. $this->assertDef('nodice:foobar;', false);
  94. $this->assertDef('position:absolute;', false);
  95. $this->assertDef('background-image:url(\'javascript:alert\(\)\');', false);
  96. // airy input
  97. $this->assertDef(' font-weight : bold; color : #ff0000',
  98. 'font-weight:bold;color:#ff0000;');
  99. // case-insensitivity
  100. $this->assertDef('FLOAT:LEFT;', 'float:left;');
  101. // !important stripping
  102. $this->assertDef('float:left !important;', 'float:left;');
  103. }
  104. function testProprietary() {
  105. $this->config->set('CSS.Proprietary', true);
  106. $this->assertDef('scrollbar-arrow-color:#ff0;');
  107. $this->assertDef('scrollbar-base-color:#ff6347;');
  108. $this->assertDef('scrollbar-darkshadow-color:#ffa500;');
  109. $this->assertDef('scrollbar-face-color:#008080;');
  110. $this->assertDef('scrollbar-highlight-color:#ff69b4;');
  111. $this->assertDef('scrollbar-shadow-color:#f0f;');
  112. $this->assertDef('opacity:.2;');
  113. $this->assertDef('-moz-opacity:.2;');
  114. $this->assertDef('-khtml-opacity:.2;');
  115. $this->assertDef('filter:alpha(opacity=20);');
  116. }
  117. function testImportant() {
  118. $this->config->set('CSS.AllowImportant', true);
  119. $this->assertDef('float:left !important;');
  120. }
  121. function testTricky() {
  122. $this->config->set('CSS.AllowTricky', true);
  123. $this->assertDef('display:none;');
  124. $this->assertDef('visibility:visible;');
  125. $this->assertDef('overflow:scroll;');
  126. }
  127. function testForbidden() {
  128. $this->config->set('CSS.ForbiddenProperties', 'float');
  129. $this->assertDef('float:left;', false);
  130. $this->assertDef('text-align:right;');
  131. }
  132. function testTrusted() {
  133. $this->config->set('CSS.Trusted', true);
  134. $this->assertDef('position:relative;');
  135. $this->assertDef('left:2px;');
  136. $this->assertDef('right:100%;');
  137. $this->assertDef('top:auto;');
  138. $this->assertDef('z-index:-2;');
  139. }
  140. }
  141. // vim: et sw=4 sts=4