diff options
author | Philipp Hagemeister <phihag@phihag.de> | 2014-01-05 01:52:03 +0100 |
---|---|---|
committer | Philipp Hagemeister <phihag@phihag.de> | 2014-01-05 01:52:03 +0100 |
commit | 6febd1c1df02870bf8b529ca758d7155cf65ab35 (patch) | |
tree | 63de20e3de64a311e680b9604a39c432831498b5 /test | |
parent | a7c26e7338ceed06b579775f315b078644a7482b (diff) |
Prepare widespread unicode literal use
Diffstat (limited to 'test')
-rw-r--r-- | test/test_unicode_literals.py | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/test/test_unicode_literals.py b/test/test_unicode_literals.py new file mode 100644 index 000000000..5f88ac2f8 --- /dev/null +++ b/test/test_unicode_literals.py @@ -0,0 +1,40 @@ +from __future__ import unicode_literals + +import io +import os +import re +import unittest + +rootDir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) + + +class TestUnicodeLiterals(unittest.TestCase): + def test_all_files(self): + print('Skipping this test (not yet fully implemtned)') + return + + for dirpath, _, filenames in os.walk(rootDir): + for basename in filenames: + if not basename.endswith('.py'): + continue + fn = os.path.join(dirpath, basename) + with io.open(fn, encoding='utf-8') as inf: + code = inf.read() + + if "'" not in code and '"' not in code: + continue + imps = 'from __future__ import unicode_literals' + self.assertTrue( + imps in code, + ' %s missing in %s' % (imps, fn)) + + m = re.search(r'(?<=\s)u[\'"](?!\)|,|$)', code) + if m is not None: + self.assertTrue( + m is None, + 'u present in %s, around %s' % ( + fn, code[m.start() - 10:m.end() + 10])) + + +if __name__ == '__main__': + unittest.main() |