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

Side by Side Diff: tests/trychange_unittest.py

Issue 248029: Make the try slave selection client side. (Closed) Base URL: svn://chrome-svn/chrome/trunk/tools/depot_tools/
Patch Set: 80 columns Created 11 years, 2 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 | Annotate | Revision Log
« no previous file with comments | « tests/presubmit_unittest.py ('k') | trychange.py » ('j') | 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/python 1 #!/usr/bin/python
2 # Copyright (c) 2009 The Chromium Authors. All rights reserved. 2 # Copyright (c) 2009 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 trychange.py.""" 6 """Unit tests for trychange.py."""
7 7
8 import optparse
8 import unittest 9 import unittest
9 10
10 # Local imports 11 # Local imports
12 import gcl
11 import super_mox 13 import super_mox
12 import trychange 14 import trychange
15 import upload
13 from super_mox import mox 16 from super_mox import mox
14 17
15 18
16 class TryChangeTestsBase(super_mox.SuperMoxTestBase): 19 class TryChangeTestsBase(super_mox.SuperMoxTestBase):
17 """Setups and tear downs the mocks but doesn't test anything as-is.""" 20 """Setups and tear downs the mocks but doesn't test anything as-is."""
18 pass 21 pass
19 22
20 23
21 class TryChangeUnittest(TryChangeTestsBase): 24 class TryChangeUnittest(TryChangeTestsBase):
22 """General trychange.py tests.""" 25 """General trychange.py tests."""
23 def testMembersChanged(self): 26 def testMembersChanged(self):
24 members = [ 27 members = [
25 'EscapeDot', 'GIT', 'GetSourceRoot', 28 'EscapeDot', 'GIT', 'GetSourceRoot',
26 'GetTryServerSettings', 'GuessVCS', 29 'GetTryServerSettings', 'GuessVCS',
27 'HELP_STRING', 'InvalidScript', 'NoTryServerAccess', 'PathDifference', 30 'HELP_STRING', 'InvalidScript', 'NoTryServerAccess', 'PathDifference',
28 'RunCommand', 'SCM', 'SVN', 'TryChange', 'USAGE', 31 'RunCommand', 'SCM', 'SVN', 'TryChange', 'USAGE',
29 'datetime', 'gcl', 'gclient', 'gclient_scm', 'getpass', 'logging', 32 'datetime', 'gcl', 'gclient', 'gclient_scm', 'getpass', 'logging',
30 'optparse', 'os', 'shutil', 'socket', 'sys', 'tempfile', 'traceback', 33 'optparse', 'os', 'presubmit_support', 'shutil', 'socket', 'subprocess',
31 'upload', 'urllib', 'subprocess', 34 'sys', 'tempfile', 'traceback', 'upload', 'urllib',
32 ] 35 ]
33 # If this test fails, you should add the relevant test. 36 # If this test fails, you should add the relevant test.
34 self.compareMembers(trychange, members) 37 self.compareMembers(trychange, members)
35 38
36 39
37 class SVNUnittest(TryChangeTestsBase): 40 class SVNUnittest(TryChangeTestsBase):
38 """trychange.SVN tests.""" 41 """trychange.SVN tests."""
42 def setUp(self):
43 self.fake_root = '/fake_root'
44 self.expected_files = ['foo.txt', 'bar.txt']
45 change_info = gcl.ChangeInfo('test_change', 0, 0, 'desc',
46 [('M', f) for f in self.expected_files],
47 self.fake_root)
48 self.svn = trychange.SVN(None)
49 self.svn.change_info = change_info
50 super_mox.SuperMoxTestBase.setUp(self)
51
39 def testMembersChanged(self): 52 def testMembersChanged(self):
40 members = [ 53 members = [
41 'GenerateDiff', 'ProcessOptions', 'options' 54 'GenerateDiff', 'GetFileNames', 'GetLocalRoot', 'ProcessOptions',
55 'options'
42 ] 56 ]
43 # If this test fails, you should add the relevant test. 57 # If this test fails, you should add the relevant test.
44 self.compareMembers(trychange.SVN(None), members) 58 self.compareMembers(trychange.SVN(None), members)
45 59
60 def testGetFileNames(self):
61 self.mox.ReplayAll()
62 self.assertEqual(self.svn.GetFileNames(), self.expected_files)
63
64 def testGetLocalRoot(self):
65 self.mox.ReplayAll()
66 self.assertEqual(self.svn.GetLocalRoot(), self.fake_root)
67
46 68
47 class GITUnittest(TryChangeTestsBase): 69 class GITUnittest(TryChangeTestsBase):
48 """trychange.GIT tests.""" 70 """trychange.GIT tests."""
71 def setUp(self):
72 self.fake_root = '/fake_root'
73 self.expected_files = ['foo.txt', 'bar.txt']
74 options = optparse.Values()
75 options.files = self.expected_files
76 self.git = trychange.GIT(options)
77 super_mox.SuperMoxTestBase.setUp(self)
78
49 def testMembersChanged(self): 79 def testMembersChanged(self):
50 members = [ 80 members = [
51 'GenerateDiff', 'GetEmail', 'GetPatchName', 'ProcessOptions', 'options' 81 'GenerateDiff', 'GetEmail', 'GetFileNames', 'GetLocalRoot',
82 'GetPatchName', 'ProcessOptions', 'options'
52 ] 83 ]
53 # If this test fails, you should add the relevant test. 84 # If this test fails, you should add the relevant test.
54 self.compareMembers(trychange.GIT(None), members) 85 self.compareMembers(trychange.GIT(None), members)
55 86
87 def testGetFileNames(self):
88 self.mox.ReplayAll()
89 self.assertEqual(self.git.GetFileNames(), self.expected_files)
90
91 def testGetLocalRoot(self):
92 self.mox.StubOutWithMock(upload, 'RunShell')
93 upload.RunShell(['git', 'rev-parse', '--show-cdup']).AndReturn(
94 self.fake_root)
95 self.mox.ReplayAll()
96 self.assertEqual(self.git.GetLocalRoot(), self.fake_root)
97
56 98
57 if __name__ == '__main__': 99 if __name__ == '__main__':
58 unittest.main() 100 unittest.main()
OLDNEW
« no previous file with comments | « tests/presubmit_unittest.py ('k') | trychange.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698