Kaydet (Commit) f08fea9e authored tarafından Victor Stinner's avatar Victor Stinner

Issue 24297: Fix test_symbol on Windows

Don't rely on end of line. Open files in text mode, not in binary mode.
üst 8aad8d6a
...@@ -15,12 +15,11 @@ TEST_PY_FILE = 'symbol_test.py' ...@@ -15,12 +15,11 @@ TEST_PY_FILE = 'symbol_test.py'
class TestSymbolGeneration(unittest.TestCase): class TestSymbolGeneration(unittest.TestCase):
def _copy_file_without_generated_symbols(self, source_file, dest_file): def _copy_file_without_generated_symbols(self, source_file, dest_file):
with open(source_file, 'rb') as fp: with open(source_file) as fp:
lines = fp.readlines() lines = fp.readlines()
nl = lines[0][len(lines[0].rstrip()):] with open(dest_file, 'w') as fp:
with open(dest_file, 'wb') as fp: fp.writelines(lines[:lines.index("#--start constants--\n") + 1])
fp.writelines(lines[:lines.index(b"#--start constants--" + nl) + 1]) fp.writelines(lines[lines.index("#--end constants--\n"):])
fp.writelines(lines[lines.index(b"#--end constants--" + nl):])
def _generate_symbols(self, grammar_file, target_symbol_py_file): def _generate_symbols(self, grammar_file, target_symbol_py_file):
proc = subprocess.Popen([sys.executable, proc = subprocess.Popen([sys.executable,
...@@ -30,18 +29,26 @@ class TestSymbolGeneration(unittest.TestCase): ...@@ -30,18 +29,26 @@ class TestSymbolGeneration(unittest.TestCase):
stderr = proc.communicate()[1] stderr = proc.communicate()[1]
return proc.returncode, stderr return proc.returncode, stderr
def compare_files(self, file1, file2):
with open(file1) as fp:
lines1 = fp.readlines()
with open(file2) as fp:
lines2 = fp.readlines()
self.assertEqual(lines1, lines2)
@unittest.skipIf(not os.path.exists(GRAMMAR_FILE), @unittest.skipIf(not os.path.exists(GRAMMAR_FILE),
'test only works from source build directory') 'test only works from source build directory')
def test_real_grammar_and_symbol_file(self): def test_real_grammar_and_symbol_file(self):
self._copy_file_without_generated_symbols(SYMBOL_FILE, TEST_PY_FILE) output = support.TESTFN
self.addCleanup(support.unlink, TEST_PY_FILE) self.addCleanup(support.unlink, output)
self.assertFalse(filecmp.cmp(SYMBOL_FILE, TEST_PY_FILE))
self.assertEqual((0, b''), self._generate_symbols(GRAMMAR_FILE, self._copy_file_without_generated_symbols(SYMBOL_FILE, output)
TEST_PY_FILE))
self.assertTrue(filecmp.cmp(SYMBOL_FILE, TEST_PY_FILE), exitcode, stderr = self._generate_symbols(GRAMMAR_FILE, output)
'symbol stat: %r\ntest_py stat: %r\n' % self.assertEqual(b'', stderr)
(os.stat(SYMBOL_FILE), self.assertEqual(0, exitcode)
os.stat(TEST_PY_FILE)))
self.compare_files(SYMBOL_FILE, output)
if __name__ == "__main__": if __name__ == "__main__":
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment