Chromium Code Reviews

Side by Side Diff: tests/gclient_scm_test.py

Issue 10559075: Give up on verifying stdout for most git gclient scm tests. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools
Patch Set: Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/usr/bin/env python 1 #!/usr/bin/env python
2 # Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 # Copyright (c) 2012 The Chromium 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 """Unit tests for gclient_scm.py.""" 6 """Unit tests for gclient_scm.py."""
7 7
8 # pylint: disable=E1103 8 # pylint: disable=E1103
9 9
10 # Import before super_mox to keep valid references. 10 # Import before super_mox to keep valid references.
(...skipping 796 matching lines...)
807 relpath=self.relpath) 807 relpath=self.relpath)
808 file_list = [] 808 file_list = []
809 scm.update(options, None, file_list) 809 scm.update(options, None, file_list)
810 gclient_scm.os.remove(file_path) 810 gclient_scm.os.remove(file_path)
811 file_list = [] 811 file_list = []
812 scm.revert(options, self.args, file_list) 812 scm.revert(options, self.args, file_list)
813 self.assertEquals(file_list, [file_path]) 813 self.assertEquals(file_list, [file_path])
814 file_list = [] 814 file_list = []
815 scm.diff(options, self.args, file_list) 815 scm.diff(options, self.args, file_list)
816 self.assertEquals(file_list, []) 816 self.assertEquals(file_list, [])
817 expectation = ('\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n' 817 #expectation = (
818 'Fast-forward\n a | 1 +\n b | 1 +\n' 818 # '\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n'
819 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n' 819 # 'Fast-forward\n a | 1 +\n b | 1 +\n'
820 '________ running \'git reset --hard origin/master\' in \'%s\'\n' 820 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n'
821 'HEAD is now at a7142dc Personalized\n') % join(self.root_dir, '.') 821 # '________ running \'git reset --hard origin/master\' in \'%s\'\n'
822 self.assertTrue(sys.stdout.getvalue().startswith(expectation)) 822 # 'HEAD is now at a7142dc Personalized\n') % join(self.root_dir, '.')
823 #self.assertTrue(sys.stdout.getvalue().startswith(expectation))
823 sys.stdout.close() 824 sys.stdout.close()
Peter Mayo 2012/06/20 14:25:17 Why does this object need to be closed all of the
M-A Ruel 2012/06/20 14:32:02 It's a mock and tearDown() verifies that no stray
824 825
825 def testRevertNone(self): 826 def testRevertNone(self):
826 if not self.enabled: 827 if not self.enabled:
827 return 828 return
828 options = self.Options() 829 options = self.Options()
829 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 830 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
830 relpath=self.relpath) 831 relpath=self.relpath)
831 file_list = [] 832 file_list = []
832 scm.update(options, None, file_list) 833 scm.update(options, None, file_list)
833 file_list = [] 834 file_list = []
834 scm.revert(options, self.args, file_list) 835 scm.revert(options, self.args, file_list)
835 self.assertEquals(file_list, []) 836 self.assertEquals(file_list, [])
836 self.assertEquals(scm.revinfo(options, self.args, None), 837 self.assertEquals(scm.revinfo(options, self.args, None),
837 'a7142dc9f0009350b96a11f372b6ea658592aa95') 838 'a7142dc9f0009350b96a11f372b6ea658592aa95')
838 self.checkstdout( 839 #self.checkstdout(
839 ('\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n' 840 # ('\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n'
840 'Fast-forward\n a | 1 +\n b | 1 +\n' 841 # 'Fast-forward\n a | 1 +\n b | 1 +\n'
841 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n' 842 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n'
842 '________ running \'git reset --hard origin/master\' in \'%s\'\n' 843 # '________ running \'git reset --hard origin/master\' in \'%s\'\n'
843 'HEAD is now at a7142dc Personalized\n') % 844 # 'HEAD is now at a7142dc Personalized\n') %
844 join(self.root_dir, '.')) 845 # join(self.root_dir, '.'))
846 sys.stdout.close()
845 847
846 def testRevertModified(self): 848 def testRevertModified(self):
847 if not self.enabled: 849 if not self.enabled:
848 return 850 return
849 options = self.Options() 851 options = self.Options()
850 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 852 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
851 relpath=self.relpath) 853 relpath=self.relpath)
852 file_list = [] 854 file_list = []
853 scm.update(options, None, file_list) 855 scm.update(options, None, file_list)
854 file_path = join(self.base_path, 'a') 856 file_path = join(self.base_path, 'a')
855 open(file_path, 'a').writelines('touched\n') 857 open(file_path, 'a').writelines('touched\n')
856 file_list = [] 858 file_list = []
857 scm.revert(options, self.args, file_list) 859 scm.revert(options, self.args, file_list)
858 self.assertEquals(file_list, [file_path]) 860 self.assertEquals(file_list, [file_path])
859 file_list = [] 861 file_list = []
860 scm.diff(options, self.args, file_list) 862 scm.diff(options, self.args, file_list)
861 self.assertEquals(file_list, []) 863 self.assertEquals(file_list, [])
862 self.assertEquals(scm.revinfo(options, self.args, None), 864 self.assertEquals(scm.revinfo(options, self.args, None),
863 'a7142dc9f0009350b96a11f372b6ea658592aa95') 865 'a7142dc9f0009350b96a11f372b6ea658592aa95')
864 expectation = ('\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n' 866 #expectation = (
865 'Fast-forward\n a | 1 +\n b | 1 +\n' 867 # '\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n'
866 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n' 868 # 'Fast-forward\n a | 1 +\n b | 1 +\n'
867 '________ running \'git reset --hard origin/master\' in \'%s\'\n' 869 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n'
868 'HEAD is now at a7142dc Personalized\n') % join(self.root_dir, '.') 870 # '________ running \'git reset --hard origin/master\' in \'%s\'\n'
869 self.assertTrue(sys.stdout.getvalue().startswith(expectation)) 871 # 'HEAD is now at a7142dc Personalized\n') % join(self.root_dir, '.')
872 #self.assertTrue(sys.stdout.getvalue().startswith(expectation))
870 sys.stdout.close() 873 sys.stdout.close()
871 874
872 def testRevertNew(self): 875 def testRevertNew(self):
873 if not self.enabled: 876 if not self.enabled:
874 return 877 return
875 options = self.Options() 878 options = self.Options()
876 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 879 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
877 relpath=self.relpath) 880 relpath=self.relpath)
878 file_list = [] 881 file_list = []
879 scm.update(options, None, file_list) 882 scm.update(options, None, file_list)
880 file_path = join(self.base_path, 'c') 883 file_path = join(self.base_path, 'c')
881 f = open(file_path, 'w') 884 f = open(file_path, 'w')
882 f.writelines('new\n') 885 f.writelines('new\n')
883 f.close() 886 f.close()
884 Popen(['git', 'add', 'c'], stdout=PIPE, 887 Popen(['git', 'add', 'c'], stdout=PIPE,
885 stderr=STDOUT, cwd=self.base_path).communicate() 888 stderr=STDOUT, cwd=self.base_path).communicate()
886 file_list = [] 889 file_list = []
887 scm.revert(options, self.args, file_list) 890 scm.revert(options, self.args, file_list)
888 self.assertEquals(file_list, [file_path]) 891 self.assertEquals(file_list, [file_path])
889 file_list = [] 892 file_list = []
890 scm.diff(options, self.args, file_list) 893 scm.diff(options, self.args, file_list)
891 self.assertEquals(file_list, []) 894 self.assertEquals(file_list, [])
892 self.assertEquals(scm.revinfo(options, self.args, None), 895 self.assertEquals(scm.revinfo(options, self.args, None),
893 'a7142dc9f0009350b96a11f372b6ea658592aa95') 896 'a7142dc9f0009350b96a11f372b6ea658592aa95')
894 expectation = ('\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n' 897 #expectation = (
895 'Fast-forward\n a | 1 +\n b | 1 +\n' 898 # '\n_____ . at refs/heads/master\nUpdating 069c602..a7142dc\n'
896 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n' 899 # 'Fast-forward\n a | 1 +\n b | 1 +\n'
897 '________ running \'git reset --hard origin/master\' in \'%s\'\n' 900 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n\n'
898 'HEAD is now at a7142dc Personalized\n') % join(self.root_dir, '.') 901 # '________ running \'git reset --hard origin/master\' in \'%s\'\n'
899 self.assertTrue(sys.stdout.getvalue().startswith(expectation)) 902 # 'HEAD is now at a7142dc Personalized\n') % join(self.root_dir, '.')
903 #self.assertTrue(sys.stdout.getvalue().startswith(expectation))
900 sys.stdout.close() 904 sys.stdout.close()
901 905
902 def testStatusNew(self): 906 def testStatusNew(self):
903 if not self.enabled: 907 if not self.enabled:
904 return 908 return
905 options = self.Options() 909 options = self.Options()
906 file_path = join(self.base_path, 'a') 910 file_path = join(self.base_path, 'a')
907 open(file_path, 'a').writelines('touched\n') 911 open(file_path, 'a').writelines('touched\n')
908 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 912 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
909 relpath=self.relpath) 913 relpath=self.relpath)
(...skipping 30 matching lines...)
940 return 944 return
941 options = self.Options() 945 options = self.Options()
942 expected_file_list = [join(self.base_path, x) for x in ['a', 'b']] 946 expected_file_list = [join(self.base_path, x) for x in ['a', 'b']]
943 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 947 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
944 relpath=self.relpath) 948 relpath=self.relpath)
945 file_list = [] 949 file_list = []
946 scm.update(options, (), file_list) 950 scm.update(options, (), file_list)
947 self.assertEquals(file_list, expected_file_list) 951 self.assertEquals(file_list, expected_file_list)
948 self.assertEquals(scm.revinfo(options, (), None), 952 self.assertEquals(scm.revinfo(options, (), None),
949 'a7142dc9f0009350b96a11f372b6ea658592aa95') 953 'a7142dc9f0009350b96a11f372b6ea658592aa95')
950 self.checkstdout( 954 #self.checkstdout(
951 '\n_____ . at refs/heads/master\n' 955 # '\n_____ . at refs/heads/master\n'
952 'Updating 069c602..a7142dc\nFast-forward\n a | 1 +\n b | 1 +\n' 956 # 'Updating 069c602..a7142dc\nFast-forward\n a | 1 +\n b | 1 +\n'
953 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n') 957 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n')
958 sys.stdout.close()
954 959
955 def testUpdateReset(self): 960 def testUpdateReset(self):
956 if not self.enabled: 961 if not self.enabled:
957 return 962 return
958 options = self.Options() 963 options = self.Options()
959 options.reset = True 964 options.reset = True
960 965
961 dir_path = join(self.base_path, 'c') 966 dir_path = join(self.base_path, 'c')
962 os.mkdir(dir_path) 967 os.mkdir(dir_path)
963 open(join(dir_path, 'nested'), 'w').writelines('new\n') 968 open(join(dir_path, 'nested'), 'w').writelines('new\n')
964 969
965 file_path = join(self.base_path, 'file') 970 file_path = join(self.base_path, 'file')
966 open(file_path, 'w').writelines('new\n') 971 open(file_path, 'w').writelines('new\n')
967 972
968 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 973 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
969 relpath=self.relpath) 974 relpath=self.relpath)
970 file_list = [] 975 file_list = []
971 scm.update(options, (), file_list) 976 scm.update(options, (), file_list)
972 self.assert_(gclient_scm.os.path.isdir(dir_path)) 977 self.assert_(gclient_scm.os.path.isdir(dir_path))
973 self.assert_(gclient_scm.os.path.isfile(file_path)) 978 self.assert_(gclient_scm.os.path.isfile(file_path))
974 self.checkstdout( 979 #self.checkstdout(
975 '\n________ running \'git reset --hard HEAD\' in \'%s\'' 980 # '\n________ running \'git reset --hard HEAD\' in \'%s\''
976 '\nHEAD is now at 069c602 A and B\n' 981 # '\nHEAD is now at 069c602 A and B\n'
977 '\n_____ . at refs/heads/master\n' 982 # '\n_____ . at refs/heads/master\n'
978 'Updating 069c602..a7142dc\nFast-forward\n a | 1 +\n b | 1 +\n' 983 # 'Updating 069c602..a7142dc\nFast-forward\n a | 1 +\n b | 1 +\n'
979 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n' 984 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n'
980 % join(self.root_dir, '.')) 985 # % join(self.root_dir, '.'))
986 sys.stdout.close()
981 987
982 def testUpdateResetDeleteUnversionedTrees(self): 988 def testUpdateResetDeleteUnversionedTrees(self):
983 if not self.enabled: 989 if not self.enabled:
984 return 990 return
985 options = self.Options() 991 options = self.Options()
986 options.reset = True 992 options.reset = True
987 options.delete_unversioned_trees = True 993 options.delete_unversioned_trees = True
988 994
989 dir_path = join(self.base_path, 'dir') 995 dir_path = join(self.base_path, 'dir')
990 os.mkdir(dir_path) 996 os.mkdir(dir_path)
991 open(join(dir_path, 'nested'), 'w').writelines('new\n') 997 open(join(dir_path, 'nested'), 'w').writelines('new\n')
992 998
993 file_path = join(self.base_path, 'file') 999 file_path = join(self.base_path, 'file')
994 open(file_path, 'w').writelines('new\n') 1000 open(file_path, 'w').writelines('new\n')
995 1001
996 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 1002 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
997 relpath=self.relpath) 1003 relpath=self.relpath)
998 file_list = [] 1004 file_list = []
999 scm.update(options, (), file_list) 1005 scm.update(options, (), file_list)
1000 self.assert_(not gclient_scm.os.path.isdir(dir_path)) 1006 self.assert_(not gclient_scm.os.path.isdir(dir_path))
1001 self.assert_(gclient_scm.os.path.isfile(file_path)) 1007 self.assert_(gclient_scm.os.path.isfile(file_path))
1002 self.checkstdout( 1008 #self.checkstdout(
1003 '\n________ running \'git reset --hard HEAD\' in \'%s\'' 1009 # '\n________ running \'git reset --hard HEAD\' in \'%s\''
1004 '\nHEAD is now at 069c602 A and B\n' 1010 # '\nHEAD is now at 069c602 A and B\n'
1005 '\n_____ . at refs/heads/master\n' 1011 # '\n_____ . at refs/heads/master\n'
1006 'Updating 069c602..a7142dc\nFast-forward\n a | 1 +\n b | 1 +\n' 1012 # 'Updating 069c602..a7142dc\nFast-forward\n a | 1 +\n b | 1 +\n'
1007 ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n' 1013 # ' 2 files changed, 2 insertions(+), 0 deletions(-)\n\n'
1008 '\n_____ removing unversioned directory dir/\n' % join(self.root_dir, 1014 # '\n_____ removing unversioned directory dir/\n' % join(self.root_dir,
1009 '.')) 1015 # '.'))
1016 sys.stdout.close()
1010 1017
1011 def testUpdateUnstagedConflict(self): 1018 def testUpdateUnstagedConflict(self):
1012 if not self.enabled: 1019 if not self.enabled:
1013 return 1020 return
1014 options = self.Options() 1021 options = self.Options()
1015 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 1022 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
1016 relpath=self.relpath) 1023 relpath=self.relpath)
1017 file_path = join(self.base_path, 'b') 1024 file_path = join(self.base_path, 'b')
1018 open(file_path, 'w').writelines('conflict\n') 1025 open(file_path, 'w').writelines('conflict\n')
1019 try: 1026 try:
(...skipping 20 matching lines...)
1040 __builtin__.raw_input = lambda x: 'y' 1047 __builtin__.raw_input = lambda x: 'y'
1041 exception = ('Conflict while rebasing this branch.\n' 1048 exception = ('Conflict while rebasing this branch.\n'
1042 'Fix the conflict and run gclient again.\n' 1049 'Fix the conflict and run gclient again.\n'
1043 'See \'man git-rebase\' for details.\n') 1050 'See \'man git-rebase\' for details.\n')
1044 self.assertRaisesError(exception, scm.update, options, (), []) 1051 self.assertRaisesError(exception, scm.update, options, (), [])
1045 exception = ('\n____ . at refs/heads/master\n' 1052 exception = ('\n____ . at refs/heads/master\n'
1046 '\tYou have unstaged changes.\n' 1053 '\tYou have unstaged changes.\n'
1047 '\tPlease commit, stash, or reset.\n') 1054 '\tPlease commit, stash, or reset.\n')
1048 self.assertRaisesError(exception, scm.update, options, (), []) 1055 self.assertRaisesError(exception, scm.update, options, (), [])
1049 # The hash always changes. Use a cheap trick. 1056 # The hash always changes. Use a cheap trick.
1050 start = ('\n________ running \'git commit -am test\' in \'%s\'\n' 1057 start = ('\n________ running \'git commit -am test\' in \'%s\'\n'
Peter Mayo 2012/06/20 14:25:17 This doesn't seem that useful, why did it get spar
M-A Ruel 2012/06/20 14:32:02 Removed it all.
1051 '[new ') % join(self.root_dir, '.') 1058 '[new ') % join(self.root_dir, '.')
1052 end = ('] test\n 1 files changed, 1 insertions(+), ' 1059 #end = ('] test\n 1 files changed, 1 insertions(+), '
1053 '1 deletions(-)\n\n_____ . at refs/heads/master\n' 1060 # '1 deletions(-)\n\n_____ . at refs/heads/master\n'
1054 'Attempting rebase onto refs/remotes/origin/master...\n') 1061 # 'Attempting rebase onto refs/remotes/origin/master...\n')
1055 self.assertTrue(sys.stdout.getvalue().startswith(start)) 1062 self.assertTrue(sys.stdout.getvalue().startswith(start))
1056 self.assertTrue(sys.stdout.getvalue().endswith(end)) 1063 #self.assertTrue(sys.stdout.getvalue().endswith(end))
1057 self.assertEquals(len(sys.stdout.getvalue()), 1064 #self.assertEquals(len(sys.stdout.getvalue()),
1058 len(start) + len(end) + 7) 1065 # len(start) + len(end) + 7)
1059 sys.stdout.close() 1066 sys.stdout.close()
1060 1067
1061 def testUpdateNotGit(self): 1068 def testUpdateNotGit(self):
1062 if not self.enabled: 1069 if not self.enabled:
1063 return 1070 return
1064 options = self.Options() 1071 options = self.Options()
1065 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir, 1072 scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
1066 relpath=self.relpath) 1073 relpath=self.relpath)
1067 git_path = join(self.base_path, '.git') 1074 git_path = join(self.base_path, '.git')
1068 rename(git_path, git_path + 'foo') 1075 rename(git_path, git_path + 'foo')
(...skipping 156 matching lines...)
1225 1232
1226 if __name__ == '__main__': 1233 if __name__ == '__main__':
1227 if '-v' in sys.argv: 1234 if '-v' in sys.argv:
1228 logging.basicConfig( 1235 logging.basicConfig(
1229 level=logging.DEBUG, 1236 level=logging.DEBUG,
1230 format='%(asctime).19s %(levelname)s %(filename)s:' 1237 format='%(asctime).19s %(levelname)s %(filename)s:'
1231 '%(lineno)s %(message)s') 1238 '%(lineno)s %(message)s')
1232 unittest.main() 1239 unittest.main()
1233 1240
1234 # vim: ts=2:sw=2:tw=80:et: 1241 # vim: ts=2:sw=2:tw=80:et:
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine