Commit 0f282063 authored by msb@chromium.org's avatar msb@chromium.org

gclient: Make revinfo work on git.

* Add revinfo as part of SCMWrapper interface.
* Implement revinfo for git and svn.
* Add unit tests.

Review URL: http://codereview.chromium.org/362008

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@31280 0039d316-1c4b-4281-b951-d872f2087c98
parent 5cc6c57b
...@@ -813,9 +813,8 @@ class GClient(object): ...@@ -813,9 +813,8 @@ class GClient(object):
if revision_overrides.has_key(name): if revision_overrides.has_key(name):
return (original_url, revision_overrides[name]) return (original_url, revision_overrides[name])
else: else:
# TODO(aharper): SVN/SCMWrapper cleanup (non-local commandset) scm = gclient_scm.CreateSCM(solution["url"], self._root_dir, name)
return (original_url, return (original_url, scm.revinfo(self._options, [], None))
gclient_scm.CaptureSVNHeadRevision(original_url))
else: else:
url_components = original_url.split("@") url_components = original_url.split("@")
if revision_overrides.has_key(name): if revision_overrides.has_key(name):
......
...@@ -78,7 +78,7 @@ class SCMWrapper(object): ...@@ -78,7 +78,7 @@ class SCMWrapper(object):
if file_list is None: if file_list is None:
file_list = [] file_list = []
commands = ['cleanup', 'export', 'update', 'revert', commands = ['cleanup', 'export', 'update', 'revert', 'revinfo',
'status', 'diff', 'pack', 'runhooks'] 'status', 'diff', 'pack', 'runhooks']
if not command in commands: if not command in commands:
...@@ -167,6 +167,10 @@ class GitWrapper(SCMWrapper): ...@@ -167,6 +167,10 @@ class GitWrapper(SCMWrapper):
self._RunGit(['reset', '--hard', merge_base], redirect_stdout=False) self._RunGit(['reset', '--hard', merge_base], redirect_stdout=False)
file_list.extend([os.path.join(self.checkout_path, f) for f in files]) file_list.extend([os.path.join(self.checkout_path, f) for f in files])
def revinfo(self, options, args, file_list):
"""Display revision"""
return self._RunGit(['rev-parse', 'HEAD'])
def runhooks(self, options, args, file_list): def runhooks(self, options, args, file_list):
self.status(options, args, file_list) self.status(options, args, file_list)
...@@ -395,6 +399,10 @@ class SVNWrapper(SCMWrapper): ...@@ -395,6 +399,10 @@ class SVNWrapper(SCMWrapper):
# exception. # exception.
logging.error('Failed to update:\n%s' % str(e)) logging.error('Failed to update:\n%s' % str(e))
def revinfo(self, options, args, file_list):
"""Display revision"""
return CaptureSVNHeadRevision(self.url)
def runhooks(self, options, args, file_list): def runhooks(self, options, args, file_list):
self.status(options, args, file_list) self.status(options, args, file_list)
......
...@@ -49,7 +49,7 @@ class SVNWrapperTestCase(gclient_test.GClientBaseTestCase): ...@@ -49,7 +49,7 @@ class SVNWrapperTestCase(gclient_test.GClientBaseTestCase):
def testDir(self): def testDir(self):
members = [ members = [
'FullUrlForRelativeUrl', 'RunCommand', 'cleanup', 'diff', 'export', 'FullUrlForRelativeUrl', 'RunCommand', 'cleanup', 'diff', 'export',
'pack', 'relpath', 'revert', 'runhooks', 'scm_name', 'status', 'pack', 'relpath', 'revert', 'revinfo', 'runhooks', 'scm_name', 'status',
'update', 'url', 'update', 'url',
] ]
...@@ -323,6 +323,39 @@ class SVNWrapperTestCase(gclient_test.GClientBaseTestCase): ...@@ -323,6 +323,39 @@ class SVNWrapperTestCase(gclient_test.GClientBaseTestCase):
} }
self.assertEqual(file_info, expected) self.assertEqual(file_info, expected)
def testRevinfo(self):
options = self.Options(verbose=False)
xml_text = """<?xml version="1.0"?>
<info>
<entry
kind="dir"
path="."
revision="35">
<url>%s</url>
<repository>
<root>%s</root>
<uuid>7b9385f5-0452-0410-af26-ad4892b7a1fb</uuid>
</repository>
<wc-info>
<schedule>normal</schedule>
<depth>infinity</depth>
</wc-info>
<commit
revision="35">
<author>maruel</author>
<date>2008-12-04T20:12:19.685120Z</date>
</commit>
</entry>
</info>
""" % (self.url, self.root_dir)
gclient_scm.CaptureSVN(['info', '--xml',
self.url], os.getcwd()).AndReturn(xml_text)
self.mox.ReplayAll()
scm = self._scm_wrapper(url=self.url, root_dir=self.root_dir,
relpath=self.relpath)
rev_info = scm.revinfo(options, self.args, None)
self.assertEqual(rev_info, '35')
class GitWrapperTestCase(gclient_test.GClientBaseTestCase): class GitWrapperTestCase(gclient_test.GClientBaseTestCase):
class OptionsObject(object): class OptionsObject(object):
...@@ -396,12 +429,6 @@ from :3 ...@@ -396,12 +429,6 @@ from :3
stderr=subprocess.STDOUT, cwd=path).communicate() stderr=subprocess.STDOUT, cwd=path).communicate()
return True return True
def GetGitRev(self, path):
return subprocess.Popen(['git', 'rev-parse', 'HEAD'],
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT,
cwd=path).communicate()[0].strip()
def setUp(self): def setUp(self):
gclient_test.BaseTestCase.setUp(self) gclient_test.BaseTestCase.setUp(self)
self.args = self.Args() self.args = self.Args()
...@@ -418,7 +445,8 @@ from :3 ...@@ -418,7 +445,8 @@ from :3
def testDir(self): def testDir(self):
members = [ members = [
'FullUrlForRelativeUrl', 'RunCommand', 'cleanup', 'diff', 'export', 'FullUrlForRelativeUrl', 'RunCommand', 'cleanup', 'diff', 'export',
'relpath', 'revert', 'runhooks', 'scm_name', 'status', 'update', 'url', 'relpath', 'revert', 'revinfo', 'runhooks', 'scm_name', 'status',
'update', 'url',
] ]
# If you add a member, be sure to add the relevant test! # If you add a member, be sure to add the relevant test!
...@@ -448,7 +476,7 @@ from :3 ...@@ -448,7 +476,7 @@ from :3
file_list = [] file_list = []
scm.revert(options, self.args, file_list) scm.revert(options, self.args, file_list)
self.assertEquals(file_list, []) self.assertEquals(file_list, [])
self.assertEquals(self.GetGitRev(self.base_path), self.assertEquals(scm.revinfo(options, self.args, None),
'069c602044c5388d2d15c3f875b057c852003458') '069c602044c5388d2d15c3f875b057c852003458')
...@@ -466,7 +494,7 @@ from :3 ...@@ -466,7 +494,7 @@ from :3
file_list = [] file_list = []
scm.diff(options, self.args, file_list) scm.diff(options, self.args, file_list)
self.assertEquals(file_list, []) self.assertEquals(file_list, [])
self.assertEquals(self.GetGitRev(self.base_path), self.assertEquals(scm.revinfo(options, self.args, None),
'069c602044c5388d2d15c3f875b057c852003458') '069c602044c5388d2d15c3f875b057c852003458')
def testRevertNew(self): def testRevertNew(self):
...@@ -487,7 +515,7 @@ from :3 ...@@ -487,7 +515,7 @@ from :3
file_list = [] file_list = []
scm.diff(options, self.args, file_list) scm.diff(options, self.args, file_list)
self.assertEquals(file_list, []) self.assertEquals(file_list, [])
self.assertEquals(self.GetGitRev(self.base_path), self.assertEquals(scm.revinfo(options, self.args, None),
'069c602044c5388d2d15c3f875b057c852003458') '069c602044c5388d2d15c3f875b057c852003458')
def testStatusNew(self): def testStatusNew(self):
...@@ -533,7 +561,7 @@ from :3 ...@@ -533,7 +561,7 @@ from :3
scm.update(options, (), file_list) scm.update(options, (), file_list)
self.assertEquals(len(file_list), 2) self.assertEquals(len(file_list), 2)
self.assert_(os.path.isfile(os.path.join(base_path, 'a'))) self.assert_(os.path.isfile(os.path.join(base_path, 'a')))
self.assertEquals(self.GetGitRev(base_path), self.assertEquals(scm.revinfo(options, (), None),
'069c602044c5388d2d15c3f875b057c852003458') '069c602044c5388d2d15c3f875b057c852003458')
finally: finally:
shutil.rmtree(root_dir) shutil.rmtree(root_dir)
...@@ -547,9 +575,19 @@ from :3 ...@@ -547,9 +575,19 @@ from :3
relpath=self.relpath) relpath=self.relpath)
file_list = [] file_list = []
scm.update(options, (), file_list) scm.update(options, (), file_list)
self.assertEquals(self.GetGitRev(self.base_path), self.assertEquals(file_list, expected_file_list)
self.assertEquals(scm.revinfo(options, (), None),
'a7142dc9f0009350b96a11f372b6ea658592aa95') 'a7142dc9f0009350b96a11f372b6ea658592aa95')
def testRevinfo(self):
if not self.enabled:
return
options = self.Options()
scm = gclient_scm.CreateSCM(url=self.url, root_dir=self.root_dir,
relpath=self.relpath)
rev_info = scm.revinfo(options, (), None)
self.assertEquals(rev_info, '069c602044c5388d2d15c3f875b057c852003458')
class RunSVNTestCase(gclient_test.BaseTestCase): class RunSVNTestCase(gclient_test.BaseTestCase):
def testRunSVN(self): def testRunSVN(self):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment