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

Side by Side Diff: tests/gclient_smoketest.py

Issue 11366239: Remove more unversioned directories. (Closed) Base URL: https://git.chromium.org/chromium/tools/depot_tools.git@master
Patch Set: Added smoke test. Created 8 years, 1 month 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_scm.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 """Smoke tests for gclient.py. 6 """Smoke tests for gclient.py.
7 7
8 Shell out 'gclient' and run basic conformance tests. 8 Shell out 'gclient' and run basic conformance tests.
9 9
10 This test assumes GClientSmokeBase.URL_BASE is valid. 10 This test assumes GClientSmokeBase.URL_BASE is valid.
11 """ 11 """
12 12
13 import logging 13 import logging
14 import os 14 import os
15 import re 15 import re
16 import subprocess 16 import subprocess
17 import sys 17 import sys
18 import unittest 18 import unittest
19 19
20 ROOT_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) 20 ROOT_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
21 sys.path.insert(0, ROOT_DIR) 21 sys.path.insert(0, ROOT_DIR)
22 22
23 from testing_support.fake_repos import join, write, FakeReposTestBase 23 from testing_support.fake_repos import join, write, FakeReposTestBase
24 import gclient_utils
25 import scm
24 26
25 import subprocess2 27 import subprocess2
26 28
27 GCLIENT_PATH = os.path.join(ROOT_DIR, 'gclient') 29 GCLIENT_PATH = os.path.join(ROOT_DIR, 'gclient')
28 COVERAGE = False 30 COVERAGE = False
29 31
30 32
31 class GClientSmokeBase(FakeReposTestBase): 33 class GClientSmokeBase(FakeReposTestBase):
32 def setUp(self): 34 def setUp(self):
33 super(GClientSmokeBase, self).setUp() 35 super(GClientSmokeBase, self).setUp()
(...skipping 743 matching lines...) Expand 10 before | Expand all | Expand 10 after
777 return 779 return
778 self.gclient(['config', self.svn_base + 'trunk/src/']) 780 self.gclient(['config', self.svn_base + 'trunk/src/'])
779 self.gclient(['sync']) 781 self.gclient(['sync'])
780 # Cripple the checkout. 782 # Cripple the checkout.
781 os.remove(join(self.root_dir, '.gclient_entries')) 783 os.remove(join(self.root_dir, '.gclient_entries'))
782 src = join(self.root_dir, 'src') 784 src = join(self.root_dir, 'src')
783 res = self.gclient(['sync', '--jobs', '1'], src) 785 res = self.gclient(['sync', '--jobs', '1'], src)
784 self.checkBlock(res[0], 786 self.checkBlock(res[0],
785 ['running', 'running', 'running']) 787 ['running', 'running', 'running'])
786 788
789 def testUnversionedRepository(self):
790 # Check that gclient automatically deletes crippled SVN repositories.
791 if not self.enabled:
792 return
793 self.gclient(['config', self.svn_base + 'trunk/src/'])
794 cmd = ['sync', '--jobs', '1', '--delete_unversioned_trees', '--reset']
795 self.assertEquals(0, self.gclient(cmd)[-1])
796 third_party = join(self.root_dir, 'src', 'third_party')
797 scm.SVN.Capture(['propset', 'svn:ignore', 'foo', '.'], cwd=third_party)
M-A Ruel 2012/11/14 20:59:29 I'd say to just subprocess it to avoid having to i
davidjames 2012/11/14 21:48:22 Done.
798
799 # Cripple src/third_party/foo and make sure gclient still succeeds.
800 gclient_utils.rmtree(join(third_party, 'foo', '.svn'))
801 self.assertEquals(0, self.gclient(cmd)[-1])
802
787 803
788 class GClientSmokeGIT(GClientSmokeBase): 804 class GClientSmokeGIT(GClientSmokeBase):
789 def setUp(self): 805 def setUp(self):
790 super(GClientSmokeGIT, self).setUp() 806 super(GClientSmokeGIT, self).setUp()
791 self.enabled = self.FAKE_REPOS.set_up_git() 807 self.enabled = self.FAKE_REPOS.set_up_git()
792 808
793 def testSync(self): 809 def testSync(self):
794 if not self.enabled: 810 if not self.enabled:
795 return 811 return
796 # TODO(maruel): safesync. 812 # TODO(maruel): safesync.
(...skipping 372 matching lines...) Expand 10 before | Expand all | Expand 10 after
1169 1185
1170 bases = {'svn': self.svn_base, 'git': self.git_base} 1186 bases = {'svn': self.svn_base, 'git': self.git_base}
1171 expected_source = [ 1187 expected_source = [
1172 ('svn', 'trunk/src/', 'src'), 1188 ('svn', 'trunk/src/', 'src'),
1173 ('git', 'repo_1', 'src-git'), 1189 ('git', 'repo_1', 'src-git'),
1174 ('svn', 'trunk/other', 'src/other'), 1190 ('svn', 'trunk/other', 'src/other'),
1175 ('git', 'repo_2@' + self.githash('repo_2', 1)[:7], 'src/repo2'), 1191 ('git', 'repo_2@' + self.githash('repo_2', 1)[:7], 'src/repo2'),
1176 ('git', 'repo_3', 'src/repo2/repo_renamed'), 1192 ('git', 'repo_3', 'src/repo2/repo_renamed'),
1177 ('svn', 'trunk/third_party/foo@1', 'src/third_party/foo'), 1193 ('svn', 'trunk/third_party/foo@1', 'src/third_party/foo'),
1178 ] 1194 ]
1179 expected = [(scm, bases[scm] + url, os.path.join(self.root_dir, path)) 1195 expected = [(scm_, bases[scm_] + url, os.path.join(self.root_dir, path))
1180 for (scm, url, path) in expected_source] 1196 for (scm_, url, path) in expected_source]
1181 1197
1182 self.assertEquals(sorted(entries), sorted(expected)) 1198 self.assertEquals(sorted(entries), sorted(expected))
1183 1199
1184 1200
1185 class GClientSmokeFromCheckout(GClientSmokeBase): 1201 class GClientSmokeFromCheckout(GClientSmokeBase):
1186 # WebKit abuses this. It has a .gclient and a DEPS from a checkout. 1202 # WebKit abuses this. It has a .gclient and a DEPS from a checkout.
1187 def setUp(self): 1203 def setUp(self):
1188 super(GClientSmokeFromCheckout, self).setUp() 1204 super(GClientSmokeFromCheckout, self).setUp()
1189 self.enabled = self.FAKE_REPOS.set_up_svn() 1205 self.enabled = self.FAKE_REPOS.set_up_svn()
1190 os.rmdir(self.root_dir) 1206 os.rmdir(self.root_dir)
(...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after
1282 1298
1283 if '-c' in sys.argv: 1299 if '-c' in sys.argv:
1284 COVERAGE = True 1300 COVERAGE = True
1285 sys.argv.remove('-c') 1301 sys.argv.remove('-c')
1286 if os.path.exists('.coverage'): 1302 if os.path.exists('.coverage'):
1287 os.remove('.coverage') 1303 os.remove('.coverage')
1288 os.environ['COVERAGE_FILE'] = os.path.join( 1304 os.environ['COVERAGE_FILE'] = os.path.join(
1289 os.path.dirname(os.path.dirname(os.path.abspath(__file__))), 1305 os.path.dirname(os.path.dirname(os.path.abspath(__file__))),
1290 '.coverage') 1306 '.coverage')
1291 unittest.main() 1307 unittest.main()
OLDNEW
« no previous file with comments | « gclient_scm.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698