| 1 | n/a | # -*- coding: koi8-r -*- |
|---|
| 2 | n/a | |
|---|
| 3 | n/a | import unittest |
|---|
| 4 | n/a | from test import support |
|---|
| 5 | n/a | |
|---|
| 6 | n/a | class PEP263Test(unittest.TestCase): |
|---|
| 7 | n/a | |
|---|
| 8 | n/a | def test_pep263(self): |
|---|
| 9 | n/a | self.assertEqual( |
|---|
| 10 | n/a | "ðÉÔÏÎ".encode("utf-8"), |
|---|
| 11 | n/a | b'\xd0\x9f\xd0\xb8\xd1\x82\xd0\xbe\xd0\xbd' |
|---|
| 12 | n/a | ) |
|---|
| 13 | n/a | self.assertEqual( |
|---|
| 14 | n/a | "\ð".encode("utf-8"), |
|---|
| 15 | n/a | b'\\\xd0\x9f' |
|---|
| 16 | n/a | ) |
|---|
| 17 | n/a | |
|---|
| 18 | n/a | def test_compilestring(self): |
|---|
| 19 | n/a | # see #1882 |
|---|
| 20 | n/a | c = compile(b"\n# coding: utf-8\nu = '\xc3\xb3'\n", "dummy", "exec") |
|---|
| 21 | n/a | d = {} |
|---|
| 22 | n/a | exec(c, d) |
|---|
| 23 | n/a | self.assertEqual(d['u'], '\xf3') |
|---|
| 24 | n/a | |
|---|
| 25 | n/a | def test_issue2301(self): |
|---|
| 26 | n/a | try: |
|---|
| 27 | n/a | compile(b"# coding: cp932\nprint '\x94\x4e'", "dummy", "exec") |
|---|
| 28 | n/a | except SyntaxError as v: |
|---|
| 29 | n/a | self.assertEqual(v.text, "print '\u5e74'\n") |
|---|
| 30 | n/a | else: |
|---|
| 31 | n/a | self.fail() |
|---|
| 32 | n/a | |
|---|
| 33 | n/a | def test_issue4626(self): |
|---|
| 34 | n/a | c = compile("# coding=latin-1\n\u00c6 = '\u00c6'", "dummy", "exec") |
|---|
| 35 | n/a | d = {} |
|---|
| 36 | n/a | exec(c, d) |
|---|
| 37 | n/a | self.assertEqual(d['\xc6'], '\xc6') |
|---|
| 38 | n/a | |
|---|
| 39 | n/a | def test_issue3297(self): |
|---|
| 40 | n/a | c = compile("a, b = '\U0001010F', '\\U0001010F'", "dummy", "exec") |
|---|
| 41 | n/a | d = {} |
|---|
| 42 | n/a | exec(c, d) |
|---|
| 43 | n/a | self.assertEqual(d['a'], d['b']) |
|---|
| 44 | n/a | self.assertEqual(len(d['a']), len(d['b'])) |
|---|
| 45 | n/a | self.assertEqual(ascii(d['a']), ascii(d['b'])) |
|---|
| 46 | n/a | |
|---|
| 47 | n/a | def test_issue7820(self): |
|---|
| 48 | n/a | # Ensure that check_bom() restores all bytes in the right order if |
|---|
| 49 | n/a | # check_bom() fails in pydebug mode: a buffer starts with the first |
|---|
| 50 | n/a | # byte of a valid BOM, but next bytes are different |
|---|
| 51 | n/a | |
|---|
| 52 | n/a | # one byte in common with the UTF-16-LE BOM |
|---|
| 53 | n/a | self.assertRaises(SyntaxError, eval, b'\xff\x20') |
|---|
| 54 | n/a | |
|---|
| 55 | n/a | # two bytes in common with the UTF-8 BOM |
|---|
| 56 | n/a | self.assertRaises(SyntaxError, eval, b'\xef\xbb\x20') |
|---|
| 57 | n/a | |
|---|
| 58 | n/a | def test_error_message(self): |
|---|
| 59 | n/a | compile(b'# -*- coding: iso-8859-15 -*-\n', 'dummy', 'exec') |
|---|
| 60 | n/a | compile(b'\xef\xbb\xbf\n', 'dummy', 'exec') |
|---|
| 61 | n/a | compile(b'\xef\xbb\xbf# -*- coding: utf-8 -*-\n', 'dummy', 'exec') |
|---|
| 62 | n/a | with self.assertRaisesRegexp(SyntaxError, 'fake'): |
|---|
| 63 | n/a | compile(b'# -*- coding: fake -*-\n', 'dummy', 'exec') |
|---|
| 64 | n/a | with self.assertRaisesRegexp(SyntaxError, 'iso-8859-15'): |
|---|
| 65 | n/a | compile(b'\xef\xbb\xbf# -*- coding: iso-8859-15 -*-\n', |
|---|
| 66 | n/a | 'dummy', 'exec') |
|---|
| 67 | n/a | with self.assertRaisesRegexp(SyntaxError, 'BOM'): |
|---|
| 68 | n/a | compile(b'\xef\xbb\xbf# -*- coding: iso-8859-15 -*-\n', |
|---|
| 69 | n/a | 'dummy', 'exec') |
|---|
| 70 | n/a | with self.assertRaisesRegexp(SyntaxError, 'fake'): |
|---|
| 71 | n/a | compile(b'\xef\xbb\xbf# -*- coding: fake -*-\n', 'dummy', 'exec') |
|---|
| 72 | n/a | with self.assertRaisesRegexp(SyntaxError, 'BOM'): |
|---|
| 73 | n/a | compile(b'\xef\xbb\xbf# -*- coding: fake -*-\n', 'dummy', 'exec') |
|---|
| 74 | n/a | |
|---|
| 75 | n/a | |
|---|
| 76 | n/a | def test_main(): |
|---|
| 77 | n/a | support.run_unittest(PEP263Test) |
|---|
| 78 | n/a | |
|---|
| 79 | n/a | if __name__=="__main__": |
|---|
| 80 | n/a | test_main() |
|---|