summaryrefslogtreecommitdiff
path: root/tests/test_phystokens.py
diff options
context:
space:
mode:
authorNed Batchelder <ned@nedbatchelder.com>2016-11-05 08:50:36 -0400
committerNed Batchelder <ned@nedbatchelder.com>2016-11-05 08:50:36 -0400
commit1752d7e0ddefb87021812d982ec998eefaed5d0f (patch)
tree0b1ef3c81014f7cd7d39cc1b121197d6015a80ef /tests/test_phystokens.py
parentb3f1198035da5576416f2096ca5e0fa19ca5ccab (diff)
downloadpython-coveragepy-git-1752d7e0ddefb87021812d982ec998eefaed5d0f.tar.gz
A fix for coding declarations, bug #529
Diffstat (limited to 'tests/test_phystokens.py')
-rw-r--r--tests/test_phystokens.py58
1 files changed, 58 insertions, 0 deletions
diff --git a/tests/test_phystokens.py b/tests/test_phystokens.py
index ccbe01b0..68456b5b 100644
--- a/tests/test_phystokens.py
+++ b/tests/test_phystokens.py
@@ -5,6 +5,7 @@
import os.path
import re
+import textwrap
from coverage import env
from coverage.phystokens import source_token_lines, source_encoding
@@ -177,6 +178,63 @@ class NeuterEncodingDeclarationTest(CoverageTest):
"Wrong encoding in %r" % neutered
)
+ def test_two_encoding_declarations(self):
+ input_src = textwrap.dedent(u"""\
+ # -*- coding: ascii -*-
+ # -*- coding: utf-8 -*-
+ # -*- coding: utf-16 -*-
+ """)
+ expected_src = textwrap.dedent(u"""\
+ # (deleted declaration) -*-
+ # (deleted declaration) -*-
+ # -*- coding: utf-16 -*-
+ """)
+ output_src = neuter_encoding_declaration(input_src)
+ self.assertEqual(expected_src, output_src)
+
+ def test_one_encoding_declaration(self):
+ input_src = textwrap.dedent(u"""\
+ # -*- coding: utf-16 -*-
+ # Just a comment.
+ # -*- coding: ascii -*-
+ """)
+ expected_src = textwrap.dedent(u"""\
+ # (deleted declaration) -*-
+ # Just a comment.
+ # -*- coding: ascii -*-
+ """)
+ output_src = neuter_encoding_declaration(input_src)
+ self.assertEqual(expected_src, output_src)
+
+
+class Bug529Test(CoverageTest):
+ """Test of bug 529"""
+
+ def test_bug_529(self):
+ self.make_file("the_test.py", '''\
+ # -*- coding: utf-8 -*-
+ import unittest
+ class FailsUnderCoverageTest(unittest.TestCase):
+ def test_fails_under_coverage(self):
+ src1 = u"""\\
+ # -*- coding: utf-8 -*-
+ # Just a comment.
+ """
+ src2 = u"""\\
+ # -*- coding: utf-8 -*-
+ # Just a comment.
+ """
+ self.assertEqual(src1, src2)
+
+ if __name__ == "__main__":
+ unittest.main()
+ ''')
+ status, out = self.run_command_status("coverage run the_test.py")
+ self.assertEqual(status, 0)
+ self.assertIn("OK", out)
+ # If this test fails, the output will be super-confusing, because it
+ # has a failing unit test contained within the failing unit test.
+
class CompileUnicodeTest(CoverageTest):
"""Tests of compiling Unicode strings."""