RoundCube Webmail
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

140 lines
6.1 KiB

  1. <?php
  2. /**
  3. * Test class to test rcube_text2html class
  4. *
  5. * @package Tests
  6. */
  7. class Framework_Text2Html extends PHPUnit_Framework_TestCase
  8. {
  9. /**
  10. * Data for test_text2html()
  11. */
  12. function data_text2html()
  13. {
  14. $options = array(
  15. 'begin' => '',
  16. 'end' => '',
  17. 'break' => '<br>',
  18. 'links' => false,
  19. 'flowed' => false,
  20. 'delsp' => false,
  21. 'wrap' => false,
  22. 'space' => '_', // replace UTF-8 non-breaking space for simpler testing
  23. 'nobr_start' => '>',
  24. 'nobr_end' => '<',
  25. );
  26. $data[] = array(" aaaa", ">_aaaa<", $options);
  27. $data[] = array("aa>aa", ">aa&gt;aa<", $options);
  28. $data[] = array("aaaa aaaa", ">aaaa_aaaa<", $options);
  29. $data[] = array("aaaa aaaa", ">aaaa__aaaa<", $options);
  30. $data[] = array("aaaa aaaa", ">aaaa___aaaa<", $options);
  31. $data[] = array("aaaa\taaaa", ">aaaa____aaaa<", $options);
  32. $data[] = array("aaaa\naaaa", "aaaa<br>aaaa", $options);
  33. $data[] = array("aaaa\n aaaa", "aaaa<br>>_aaaa<", $options);
  34. $data[] = array("aaaa\n aaaa", "aaaa<br>>__aaaa<", $options);
  35. $data[] = array("aaaa\n aaaa", "aaaa<br>>___aaaa<", $options);
  36. $data[] = array("\n", "<br>", $options);
  37. $data[] = array("\taaaa", ">____aaaa<", $options);
  38. $data[] = array("\naaaa", "<br>aaaa", $options);
  39. $data[] = array("\n aaaa", "<br>>_aaaa<", $options);
  40. $data[] = array("\n aaaa", "<br>>__aaaa<", $options);
  41. $data[] = array("\n aaaa", "<br>>___aaaa<", $options);
  42. $data[] = array("aaaa\n\nbbbb", "aaaa<br><br>bbbb", $options);
  43. $data[] = array(">aaaa \n>aaaa", "<blockquote>>aaaa_<<br>aaaa</blockquote>", $options);
  44. $data[] = array(">aaaa\n>aaaa", "<blockquote>aaaa<br>aaaa</blockquote>", $options);
  45. $data[] = array(">aaaa \n>bbbb\ncccc dddd", "<blockquote>>aaaa_<<br>bbbb</blockquote>>cccc_dddd<", $options);
  46. $data[] = array("aaaa-bbbb/cccc", ">aaaa-bbbb/cccc<", $options);
  47. $data[] = array("aaaa-bbbb\r\tcccc", ">aaaa-bbbb____cccc<", $options);
  48. $options['flowed'] = true;
  49. $data[] = array(" aaaa", "aaaa", $options);
  50. $data[] = array("aaaa aaaa", ">aaaa_aaaa<", $options);
  51. $data[] = array("aaaa aaaa", ">aaaa__aaaa<", $options);
  52. $data[] = array("aaaa aaaa", ">aaaa___aaaa<", $options);
  53. $data[] = array("aaaa\taaaa", ">aaaa____aaaa<", $options);
  54. $data[] = array("aaaa\naaaa", "aaaa<br>aaaa", $options);
  55. $data[] = array("aaaa\n aaaa", "aaaa<br>aaaa", $options);
  56. $data[] = array("aaaa\n aaaa", "aaaa<br>>_aaaa<", $options);
  57. $data[] = array("aaaa\n aaaa", "aaaa<br>>__aaaa<", $options);
  58. $data[] = array("\taaaa", ">____aaaa<", $options);
  59. $data[] = array("\naaaa", "<br>aaaa", $options);
  60. $data[] = array("\n aaaa", "<br>aaaa", $options);
  61. $data[] = array("\n aaaa", "<br>>_aaaa<", $options);
  62. $data[] = array("\n aaaa", "<br>>__aaaa<", $options);
  63. $data[] = array("aaaa\n\nbbbb", "aaaa<br><br>bbbb", $options);
  64. $data[] = array(">aaaa \n>aaaa", "<blockquote>aaaa aaaa</blockquote>", $options);
  65. $data[] = array(">aaaa\n>aaaa", "<blockquote>aaaa<br>aaaa</blockquote>", $options);
  66. $data[] = array(">aaaa \n>bbbb\ncccc dddd", "<blockquote>aaaa bbbb</blockquote>>cccc_dddd<", $options);
  67. $data[] = array("\x02\x03", ">\x02\x03<", $options);
  68. $options['flowed'] = true;
  69. $options['delsp'] = true;
  70. $data[] = array(" aaaa", "aaaa", $options);
  71. $data[] = array("aaaa aaaa", ">aaaa_aaaa<", $options);
  72. $data[] = array("aaaa aaaa", ">aaaa__aaaa<", $options);
  73. $data[] = array("aaaa aaaa", ">aaaa___aaaa<", $options);
  74. $data[] = array("aaaa\taaaa", ">aaaa____aaaa<", $options);
  75. $data[] = array("aaaa\naaaa", "aaaa<br>aaaa", $options);
  76. $data[] = array("aaaa\n aaaa", "aaaa<br>aaaa", $options);
  77. $data[] = array("aaaa\n aaaa", "aaaa<br>>_aaaa<", $options);
  78. $data[] = array("aaaa\n aaaa", "aaaa<br>>__aaaa<", $options);
  79. $data[] = array("\taaaa", ">____aaaa<", $options);
  80. $data[] = array("\naaaa", "<br>aaaa", $options);
  81. $data[] = array("\n aaaa", "<br>aaaa", $options);
  82. $data[] = array("\n aaaa", "<br>>_aaaa<", $options);
  83. $data[] = array("\n aaaa", "<br>>__aaaa<", $options);
  84. $data[] = array("aaaa\n\nbbbb", "aaaa<br><br>bbbb", $options);
  85. $data[] = array(">aaaa \n>aaaa", "<blockquote>aaaaaaaa</blockquote>", $options);
  86. $data[] = array(">aaaa\n>aaaa", "<blockquote>aaaa<br>aaaa</blockquote>", $options);
  87. $data[] = array(">aaaa \n>bbbb\ncccc dddd", "<blockquote>aaaabbbb</blockquote>>cccc_dddd<", $options);
  88. $options['flowed'] = false;
  89. $options['delsp'] = false;
  90. $options['wrap'] = true;
  91. $data[] = array(">>aaaa bbbb\n>>\n>>>\n>cccc\n\ndddd eeee",
  92. "<blockquote><blockquote>aaaa bbbb<br><br><blockquote><br></blockquote></blockquote>cccc</blockquote><br>dddd eeee", $options);
  93. $data[] = array("\n>>aaaa\n\ndddd",
  94. "<br><blockquote><blockquote>aaaa</blockquote></blockquote><br>dddd", $options);
  95. $data[] = array("aaaa\n>bbbb\n>cccc\n\ndddd\n>>test",
  96. "aaaa<blockquote>bbbb<br>cccc</blockquote><br>dddd<blockquote><blockquote>test</blockquote></blockquote>", $options);
  97. return $data;
  98. }
  99. /**
  100. * Test text to html conversion
  101. *
  102. * @dataProvider data_text2html
  103. */
  104. function test_text2html($input, $output, $options)
  105. {
  106. $t2h = new rcube_text2html($input, false, $options);
  107. $html = $t2h->get_html();
  108. $this->assertEquals($output, $html);
  109. }
  110. /**
  111. * Test XSS issue
  112. */
  113. function test_text2html_xss()
  114. {
  115. $input = "\n[<script>evil</script>]:##str_replacement_0##\n";
  116. $t2h = new rcube_text2html($input);
  117. $html = $t2h->get_html();
  118. $expected = "<div class=\"pre\"><br>\n"
  119. . "[&lt;script&gt;evil&lt;/script&gt;]:##str_replacement_0##<br>\n"
  120. . "</div>";
  121. $this->assertEquals($expected, $html);
  122. }
  123. }