Thomas Bruederli
2014-02-04 eecd9ce0f908ffdff10613a0e2c55f2c28f093dc
Fix infinite loop when converting invalid html to plaintext (#1489566)
2 files modified
32 ■■■■■ changed files
program/lib/Roundcube/rcube_html2text.php 4 ●●●● patch | view | raw | blame | history
tests/Framework/Html2text.php 28 ●●●●● patch | view | raw | blame | history
program/lib/Roundcube/rcube_html2text.php
@@ -616,6 +616,10 @@
                    break;
                }
                // abort on invalid tag structure (e.g. no closing tag found)
                else {
                    break;
                }
            }
            while ($end || $next);
        }
tests/Framework/Html2text.php
@@ -75,4 +75,32 @@
        $this->assertContains('>> INNER 3', $res, 'Quote inner');
        $this->assertContains('> OUTER END', $res, 'Quote outer');
    }
    function test_broken_blockquotes()
    {
        // no end tag
        $html = <<<EOF
Begin<br>
<blockquote>QUOTED TEXT
<blockquote>
NO END TAG FOUND
EOF;
        $ht = new rcube_html2text($html, false, false);
        $res = $ht->get_text();
        $this->assertContains('QUOTED TEXT NO END TAG FOUND', $res, 'No quoating on invalid html');
        // with some (nested) end tags
        $html = <<<EOF
Begin<br>
<blockquote>QUOTED TEXT
<blockquote>INNER 1</blockquote>
<blockquote>INNER 2</blockquote>
NO END TAG FOUND
EOF;
        $ht = new rcube_html2text($html, false, false);
        $res = $ht->get_text();
        $this->assertContains('QUOTED TEXT INNER 1 INNER 2 NO END', $res, 'No quoating on invalid html');
    }
}