Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(950)

Side by Side Diff: tests/gclient_scm_test.py

Issue 2300633002: Make use of CheckCallAndFilter42 for gclient's git fetch. (Closed)
Patch Set: Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « gclient_utils.py ('k') | 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 952 matching lines...) Expand 10 before | Expand all | Expand 10 after
963 relpath=self.relpath) 963 relpath=self.relpath)
964 file_list = [] 964 file_list = []
965 options.revision = 'unmanaged' 965 options.revision = 'unmanaged'
966 scm.update(options, (), file_list) 966 scm.update(options, (), file_list)
967 self.assertEquals(file_list, expected_file_list) 967 self.assertEquals(file_list, expected_file_list)
968 self.assertEquals(scm.revinfo(options, (), None), 968 self.assertEquals(scm.revinfo(options, (), None),
969 '069c602044c5388d2d15c3f875b057c852003458') 969 '069c602044c5388d2d15c3f875b057c852003458')
970 self.checkstdout('________ unmanaged solution; skipping .\n') 970 self.checkstdout('________ unmanaged solution; skipping .\n')
971 971
972 972
973 class GitHungTest(BaseGitWrapperTestCase):
974 def setUp(self):
975 super(GitHungTest, self).setUp()
976 self.old = gclient_scm.gclient_utils.CheckCallAndFilter
977 self.old2 = gclient_scm.gclient_utils.subprocess2.Popen
978 self.options = self.Options()
979 self.options.verbose = False
980 self.scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
981 relpath=self.relpath)
982 os.environ['GCLIENT_KILL_GIT_FETCH_AFTER'] = '1.0'
983
984 def tearDown(self):
985 os.environ.pop('GCLIENT_KILL_GIT_FETCH_AFTER')
986 gclient_scm.gclient_utils.CheckCallAndFilter = self.old
987 gclient_scm.gclient_utils.subprocess2.Popen = self.old2
988 super(GitHungTest, self).tearDown()
989
990 def testGitFetchOk(self):
991 def subprocess_git_fetch_run(_, filter_fn, kill_timeout, **__):
992 self.assertEqual(kill_timeout, 1.0)
993 filter_fn('remote: something')
994 gclient_scm.gclient_utils.CheckCallAndFilter = subprocess_git_fetch_run
995 self.scm._Fetch(self.options)
996 self.checkstdout('remote: something\n')
997
998 def testGitFetchHungAndRetry(self):
999 class Process(object):
1000 # First process will hang, second process will exit with 0 quickly.
1001 cv = threading.Condition()
1002 count = -1
1003 killed = []
1004 def __init__(self):
1005 self.count += 1
1006 self.stdout = self
1007 self.data = list('retry' if self.count > 0 else 'hung')
1008 self.data.reverse()
1009 self.this_killed = False
1010 def read(self, _):
1011 if self.data:
1012 return self.data.pop()
1013 if self.count == 0:
1014 # Simulate hung process.
1015 with self.cv:
1016 self.cv.wait(timeout=0)
1017 return ''
1018 def kill(self):
1019 self.this_killed = True
1020 self.killed.append(self.count)
1021 with self.cv:
1022 self.cv.notify()
1023 def wait(self):
1024 if self.this_killed:
1025 return 1
1026 return 0
1027
1028 gclient_scm.gclient_utils.subprocess2.Popen = lambda *_, **__: Process()
1029 self.scm._Capture = lambda *_, **__: None
1030 self.scm._Fetch(self.options)
1031 self.checkstdout('hung\n')
1032
1033
1034 if __name__ == '__main__': 973 if __name__ == '__main__':
1035 level = logging.DEBUG if '-v' in sys.argv else logging.FATAL 974 level = logging.DEBUG if '-v' in sys.argv else logging.FATAL
1036 logging.basicConfig( 975 logging.basicConfig(
1037 level=level, 976 level=level,
1038 format='%(asctime).19s %(levelname)s %(filename)s:' 977 format='%(asctime).19s %(levelname)s %(filename)s:'
1039 '%(lineno)s %(message)s') 978 '%(lineno)s %(message)s')
1040 unittest.main() 979 unittest.main()
1041 980
1042 # vim: ts=2:sw=2:tw=80:et: 981 # vim: ts=2:sw=2:tw=80:et:
OLDNEW
« no previous file with comments | « gclient_utils.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698