diff options
| author | Ezio Melotti <ezio.melotti@gmail.com> | 2013-05-01 16:18:25 +0300 | 
|---|---|---|
| committer | Ezio Melotti <ezio.melotti@gmail.com> | 2013-05-01 16:18:25 +0300 | 
| commit | 8e596a765cf323cbd2ba31b15f2939f903d87913 (patch) | |
| tree | 184a1f476856981e2aee50ee2ec9939994916ce6 /Lib/test/test_htmlparser.py | |
| parent | a771a1b48e7fcf73b13e905f87f319fcd4cb25b2 (diff) | |
| download | cpython-git-8e596a765cf323cbd2ba31b15f2939f903d87913.tar.gz | |
#17802: Fix an UnboundLocalError in html.parser.  Initial tests by Thomas Barlow.
Diffstat (limited to 'Lib/test/test_htmlparser.py')
| -rw-r--r-- | Lib/test/test_htmlparser.py | 14 | 
1 files changed, 14 insertions, 0 deletions
| diff --git a/Lib/test/test_htmlparser.py b/Lib/test/test_htmlparser.py index c5d878dca5..b15b6fd4c6 100644 --- a/Lib/test/test_htmlparser.py +++ b/Lib/test/test_htmlparser.py @@ -535,6 +535,20 @@ class HTMLParserTolerantTestCase(HTMLParserStrictTestCase):          ]          self._run_check(html, expected) +    def test_EOF_in_charref(self): +        # see #17802 +        # This test checks that the UnboundLocalError reported in the issue +        # is not raised, however I'm not sure the returned values are correct. +        # Maybe HTMLParser should use self.unescape for these +        data = [ +            ('a&', [('data', 'a&')]), +            ('a&b', [('data', 'ab')]), +            ('a&b ', [('data', 'a'), ('entityref', 'b'), ('data', ' ')]), +            ('a&b;', [('data', 'a'), ('entityref', 'b')]), +        ] +        for html, expected in data: +            self._run_check(html, expected) +      def test_unescape_function(self):          p = self.get_collector()          self.assertEqual(p.unescape('&#bad;'),'&#bad;') | 
