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.

177 lines
7.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 = [
  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[] = [" aaaa", ">_aaaa<", $options];
  27. $data[] = ["aa>aa", ">aa&gt;aa<", $options];
  28. $data[] = ["aaaa aaaa", ">aaaa_aaaa<", $options];
  29. $data[] = ["aaaa aaaa", ">aaaa__aaaa<", $options];
  30. $data[] = ["aaaa aaaa", ">aaaa___aaaa<", $options];
  31. $data[] = ["aaaa\taaaa", ">aaaa____aaaa<", $options];
  32. $data[] = ["aaaa\naaaa", "aaaa<br>aaaa", $options];
  33. $data[] = ["aaaa\n aaaa", "aaaa<br>>_aaaa<", $options];
  34. $data[] = ["aaaa\n aaaa", "aaaa<br>>__aaaa<", $options];
  35. $data[] = ["aaaa\n aaaa", "aaaa<br>>___aaaa<", $options];
  36. $data[] = ["\n", "<br>", $options];
  37. $data[] = ["\taaaa", ">____aaaa<", $options];
  38. $data[] = ["\naaaa", "<br>aaaa", $options];
  39. $data[] = ["\n aaaa", "<br>>_aaaa<", $options];
  40. $data[] = ["\n aaaa", "<br>>__aaaa<", $options];
  41. $data[] = ["\n aaaa", "<br>>___aaaa<", $options];
  42. $data[] = ["aaaa\n\nbbbb", "aaaa<br><br>bbbb", $options];
  43. $data[] = [">aaaa \n>aaaa", "<blockquote>>aaaa_<<br>aaaa</blockquote>", $options];
  44. $data[] = [">aaaa\n>aaaa", "<blockquote>aaaa<br>aaaa</blockquote>", $options];
  45. $data[] = [">aaaa \n>bbbb\ncccc dddd", "<blockquote>>aaaa_<<br>bbbb</blockquote>>cccc_dddd<", $options];
  46. $data[] = ["aaaa-bbbb/cccc", ">aaaa-bbbb/cccc<", $options];
  47. $data[] = ["aaaa-bbbb\r\tcccc", ">aaaa-bbbb____cccc<", $options];
  48. $options['flowed'] = true;
  49. $data[] = [" aaaa", "aaaa", $options];
  50. $data[] = ["aaaa aaaa", ">aaaa_aaaa<", $options];
  51. $data[] = ["aaaa aaaa", ">aaaa__aaaa<", $options];
  52. $data[] = ["aaaa aaaa", ">aaaa___aaaa<", $options];
  53. $data[] = ["aaaa\taaaa", ">aaaa____aaaa<", $options];
  54. $data[] = ["aaaa\naaaa", "aaaa<br>aaaa", $options];
  55. $data[] = ["aaaa\n aaaa", "aaaa<br>aaaa", $options];
  56. $data[] = ["aaaa\n aaaa", "aaaa<br>>_aaaa<", $options];
  57. $data[] = ["aaaa\n aaaa", "aaaa<br>>__aaaa<", $options];
  58. $data[] = ["\taaaa", ">____aaaa<", $options];
  59. $data[] = ["\naaaa", "<br>aaaa", $options];
  60. $data[] = ["\n aaaa", "<br>aaaa", $options];
  61. $data[] = ["\n aaaa", "<br>>_aaaa<", $options];
  62. $data[] = ["\n aaaa", "<br>>__aaaa<", $options];
  63. $data[] = ["aaaa\n\nbbbb", "aaaa<br><br>bbbb", $options];
  64. $data[] = [">aaaa \n>aaaa", "<blockquote>aaaa aaaa</blockquote>", $options];
  65. $data[] = [">aaaa\n>aaaa", "<blockquote>aaaa<br>aaaa</blockquote>", $options];
  66. $data[] = [">aaaa \n>bbbb\ncccc dddd", "<blockquote>aaaa bbbb</blockquote>>cccc_dddd<", $options];
  67. $data[] = ["\x02\x03", ">\x02\x03<", $options];
  68. $options['flowed'] = true;
  69. $options['delsp'] = true;
  70. $data[] = [" aaaa", "aaaa", $options];
  71. $data[] = ["aaaa aaaa", ">aaaa_aaaa<", $options];
  72. $data[] = ["aaaa aaaa", ">aaaa__aaaa<", $options];
  73. $data[] = ["aaaa aaaa", ">aaaa___aaaa<", $options];
  74. $data[] = ["aaaa\taaaa", ">aaaa____aaaa<", $options];
  75. $data[] = ["aaaa\naaaa", "aaaa<br>aaaa", $options];
  76. $data[] = ["aaaa\n aaaa", "aaaa<br>aaaa", $options];
  77. $data[] = ["aaaa\n aaaa", "aaaa<br>>_aaaa<", $options];
  78. $data[] = ["aaaa\n aaaa", "aaaa<br>>__aaaa<", $options];
  79. $data[] = ["\taaaa", ">____aaaa<", $options];
  80. $data[] = ["\naaaa", "<br>aaaa", $options];
  81. $data[] = ["\n aaaa", "<br>aaaa", $options];
  82. $data[] = ["\n aaaa", "<br>>_aaaa<", $options];
  83. $data[] = ["\n aaaa", "<br>>__aaaa<", $options];
  84. $data[] = ["aaaa\n\nbbbb", "aaaa<br><br>bbbb", $options];
  85. $data[] = [">aaaa \n>aaaa", "<blockquote>aaaaaaaa</blockquote>", $options];
  86. $data[] = [">aaaa\n>aaaa", "<blockquote>aaaa<br>aaaa</blockquote>", $options];
  87. $data[] = [">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[] = [">>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[] = ["\n>>aaaa\n\ndddd",
  94. "<br><blockquote><blockquote>aaaa</blockquote></blockquote><br>dddd", $options];
  95. $data[] = ["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. /**
  124. * Test XSS issue
  125. */
  126. function test_text2html_xss2()
  127. {
  128. $input = "\n[<script>evil</script>] https://google.com\n";
  129. $t2h = new rcube_text2html($input);
  130. $html = $t2h->get_html();
  131. $expected = "<div class=\"pre\"><br>\n[&lt;script&gt;evil&lt;/script&gt;] "
  132. . "<a rel=\"noreferrer\" target=\"_blank\" href=\"https://google.com\">https://google.com</a><br>\n"
  133. . "</div>";
  134. $this->assertEquals($expected, $html);
  135. }
  136. /**
  137. * Test bug #8021
  138. */
  139. function test_text2html_8021()
  140. {
  141. $input = "Test1 [1]\n\n[1] http://d1.tld\n\nyou wrote:\n> Test2 [1]\n>\n> [1] http://d2.tld";
  142. $expected = '<div class="pre">Test1 [<a href="http://d1.tld">1</a>]'
  143. . "<br>\n<br>\n"
  144. . '[1] <a href="http://d1.tld">http://d1.tld</a>'
  145. . "<br>\n<br>\n"
  146. . 'you wrote:<blockquote>Test2 [<a href="http://d2.tld">1</a>]'
  147. . "<br>\n<br>\n"
  148. . '[1] <a href="http://d2.tld">http://d2.tld</a></blockquote></div>';
  149. $t2h = new rcube_text2html($input);
  150. $html = $t2h->get_html();
  151. $html = preg_replace('/ (rel|target)="(noreferrer|_blank)"/', '', $html);
  152. $this->assertEquals($expected, $html);
  153. }
  154. }