| OLD | NEW |
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # Copyright 2017 the V8 project authors. All rights reserved. | 2 # Copyright 2017 the V8 project authors. All rights reserved. |
| 3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be |
| 4 # found in the LICENSE file. | 4 # found in the LICENSE file. |
| 5 | 5 |
| 6 import os | 6 import os |
| 7 import shutil | 7 import shutil |
| 8 import subprocess | 8 import subprocess |
| 9 import sys | 9 import sys |
| 10 import tempfile | 10 import tempfile |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 !/testing/gtest/include | 22 !/testing/gtest/include |
| 23 /testing/gtest/include/* | 23 /testing/gtest/include/* |
| 24 !/testing/gtest/include/gtest | 24 !/testing/gtest/include/gtest |
| 25 /testing/gtest/include/gtest/* | 25 /testing/gtest/include/gtest/* |
| 26 !/testing/gtest/include/gtest/gtest_prod.h | 26 !/testing/gtest/include/gtest/gtest_prod.h |
| 27 !/third_party/jinja2 | 27 !/third_party/jinja2 |
| 28 !/third_party/markupsafe | 28 !/third_party/markupsafe |
| 29 /unrelated | 29 /unrelated |
| 30 """ | 30 """ |
| 31 | 31 |
| 32 EXPECTED_GIT_DIFF = """ |
| 33 rename deps/v8/baz/{delete_me => v8_new} (100%) |
| 34 rename deps/v8/{delete_me => new/v8_new} (100%) |
| 35 create mode 100644 deps/v8/third_party/jinja2/jinja2 |
| 36 create mode 100644 deps/v8/third_party/markupsafe/markupsafe |
| 37 create mode 100644 deps/v8/v8_new |
| 38 """ |
| 39 |
| 32 ADDED_FILES = [ | 40 ADDED_FILES = [ |
| 33 'v8_new', | 41 'v8_new', |
| 34 'new/v8_new', | 42 'new/v8_new', |
| 35 'baz/v8_new', | 43 'baz/v8_new', |
| 36 'testing/gtest/gtest_new', | 44 'testing/gtest/gtest_new', |
| 37 'testing/gtest/new/gtest_new', | 45 'testing/gtest/new/gtest_new', |
| 38 'testing/gtest/baz/gtest_new', | 46 'testing/gtest/baz/gtest_new', |
| 39 'third_party/jinja2/jinja2', | 47 'third_party/jinja2/jinja2', |
| 40 'third_party/markupsafe/markupsafe' | 48 'third_party/markupsafe/markupsafe' |
| 41 ] | 49 ] |
| 42 | 50 |
| 43 REMOVED_FILES = [ | 51 REMOVED_FILES = [ |
| 44 'delete_me', | 52 'delete_me', |
| 45 'baz/delete_me', | 53 'baz/delete_me', |
| 46 'testing/gtest/delete_me', | 54 'testing/gtest/delete_me', |
| 47 'testing/gtest/baz/delete_me', | 55 'testing/gtest/baz/delete_me', |
| 48 ] | 56 ] |
| 49 | 57 |
| 50 def gitify(path): | 58 def gitify(path): |
| 51 files = os.listdir(path) | 59 files = os.listdir(path) |
| 52 subprocess.check_call(['git', 'init'], cwd=path) | 60 subprocess.check_call(['git', 'init'], cwd=path) |
| 53 subprocess.check_call(['git', 'add'] + files, cwd=path) | 61 subprocess.check_call(['git', 'add'] + files, cwd=path) |
| 54 subprocess.check_call(['git', 'commit', '-m="Initial"'], cwd=path) | 62 subprocess.check_call(['git', 'commit', '-m', 'Initial'], cwd=path) |
| 55 | 63 |
| 56 | 64 |
| 57 class TestUpdateNode(unittest.TestCase): | 65 class TestUpdateNode(unittest.TestCase): |
| 58 def setUp(self): | 66 def setUp(self): |
| 59 self.workdir = tempfile.mkdtemp(prefix='tmp_test_node_') | 67 self.workdir = tempfile.mkdtemp(prefix='tmp_test_node_') |
| 60 | 68 |
| 61 def tearDown(self): | 69 def tearDown(self): |
| 62 shutil.rmtree(self.workdir) | 70 shutil.rmtree(self.workdir) |
| 63 | 71 |
| 64 def testUpdate(self): | 72 def testUpdate(self): |
| 65 v8_cwd = os.path.join(self.workdir, 'v8') | 73 v8_cwd = os.path.join(self.workdir, 'v8') |
| 66 node_cwd = os.path.join(self.workdir, 'node') | 74 node_cwd = os.path.join(self.workdir, 'node') |
| 67 | 75 |
| 68 # Set up V8 test fixture. | 76 # Set up V8 test fixture. |
| 69 shutil.copytree(src=os.path.join(TEST_DATA, 'v8'), dst=v8_cwd) | 77 shutil.copytree(src=os.path.join(TEST_DATA, 'v8'), dst=v8_cwd) |
| 70 gitify(v8_cwd) | 78 gitify(v8_cwd) |
| 71 for repository in update_node.SUB_REPOSITORIES: | 79 for repository in update_node.SUB_REPOSITORIES: |
| 72 gitify(os.path.join(v8_cwd, *repository)) | 80 gitify(os.path.join(v8_cwd, *repository)) |
| 73 | 81 |
| 74 # Set up node test fixture (no git repo required). | 82 # Set up node test fixture. |
| 75 shutil.copytree(src=os.path.join(TEST_DATA, 'node'), dst=node_cwd) | 83 shutil.copytree(src=os.path.join(TEST_DATA, 'node'), dst=node_cwd) |
| 84 gitify(os.path.join(node_cwd)) |
| 76 | 85 |
| 77 # Run update script. | 86 # Run update script. |
| 78 update_node.Main([v8_cwd, node_cwd]) | 87 update_node.Main([v8_cwd, node_cwd, "--commit"]) |
| 79 | 88 |
| 80 # Check expectations. | 89 # Check expectations. |
| 81 with open(os.path.join(node_cwd, 'deps', 'v8', '.gitignore')) as f: | 90 with open(os.path.join(node_cwd, 'deps', 'v8', '.gitignore')) as f: |
| 82 actual_gitignore = f.read() | 91 actual_gitignore = f.read() |
| 83 self.assertEquals(EXPECTED_GITIGNORE.strip(), actual_gitignore.strip()) | 92 self.assertEquals(EXPECTED_GITIGNORE.strip(), actual_gitignore.strip()) |
| 84 for f in ADDED_FILES: | 93 for f in ADDED_FILES: |
| 85 added_file = os.path.join(node_cwd, 'deps', 'v8', *f.split('/')) | 94 added_file = os.path.join(node_cwd, 'deps', 'v8', *f.split('/')) |
| 86 self.assertTrue(os.path.exists(added_file)) | 95 self.assertTrue(os.path.exists(added_file)) |
| 87 for f in REMOVED_FILES: | 96 for f in REMOVED_FILES: |
| 88 removed_file = os.path.join(node_cwd, 'deps', 'v8', *f.split('/')) | 97 removed_file = os.path.join(node_cwd, 'deps', 'v8', *f.split('/')) |
| 89 self.assertFalse(os.path.exists(removed_file)) | 98 self.assertFalse(os.path.exists(removed_file)) |
| 99 gitlog = subprocess.check_output(['git', 'diff', 'master', '--summary'], |
| 100 cwd=node_cwd) |
| 101 self.assertEquals(EXPECTED_GIT_DIFF.strip(), gitlog.strip()) |
| 90 | 102 |
| 91 if __name__ == "__main__": | 103 if __name__ == "__main__": |
| 92 unittest.main() | 104 unittest.main() |
| OLD | NEW |