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

Unified Diff: tests/scm_unittest.py

Issue 389020: Split scm-specific functions out of gclient_scm.py to scm.py. (Closed)
Patch Set: 80 cols Created 11 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/gclient_test.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/scm_unittest.py
diff --git a/tests/scm_unittest.py b/tests/scm_unittest.py
new file mode 100755
index 0000000000000000000000000000000000000000..68846d71e147ac724a575e5b93dbd852ec9269b0
--- /dev/null
+++ b/tests/scm_unittest.py
@@ -0,0 +1,279 @@
+#!/usr/bin/python
+# Copyright (c) 2006-2009 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+"""Unit tests for scm.py."""
+
+from gclient_test import BaseTestCase
+import scm
+from super_mox import mox
+
+
+class BaseSCMTestCase(BaseTestCase):
+ def setUp(self):
+ BaseTestCase.setUp(self)
+ self.mox.StubOutWithMock(scm.gclient_utils, 'SubprocessCall')
+ self.mox.StubOutWithMock(scm.gclient_utils, 'SubprocessCallAndFilter')
+
+
+class RootTestCase(BaseSCMTestCase):
+ def testMembersChanged(self):
+ self.mox.ReplayAll()
+ members = [
+ 'CaptureGit', 'CaptureGitStatus', 'GIT_COMMAND',
+ 'CaptureSVN', 'CaptureSVNHeadRevision', 'CaptureSVNInfo',
+ 'CaptureSVNStatus', 'RunSVN', 'RunSVNAndFilterOutput',
+ 'RunSVNAndGetFileList', 'SVN_COMMAND',
+ 'gclient_utils', 'os', 're', 'subprocess', 'sys', 'xml',
+ ]
+ # If this test fails, you should add the relevant test.
+ self.compareMembers(scm, members)
+
+
+class GitWrapperTestCase(BaseSCMTestCase):
+ sample_git_import = """blob
+mark :1
+data 6
+Hello
+
+blob
+mark :2
+data 4
+Bye
+
+reset refs/heads/master
+commit refs/heads/master
+mark :3
+author Bob <bob@example.com> 1253744361 -0700
+committer Bob <bob@example.com> 1253744361 -0700
+data 8
+A and B
+M 100644 :1 a
+M 100644 :2 b
+
+blob
+mark :4
+data 10
+Hello
+You
+
+blob
+mark :5
+data 8
+Bye
+You
+
+commit refs/heads/origin
+mark :6
+author Alice <alice@example.com> 1253744424 -0700
+committer Alice <alice@example.com> 1253744424 -0700
+data 13
+Personalized
+from :3
+M 100644 :4 a
+M 100644 :5 b
+
+reset refs/heads/master
+from :3
+"""
+
+ def CreateGitRepo(self, git_import, path):
+ try:
+ subprocess.Popen(['git', 'init'], stdout=subprocess.PIPE,
+ stderr=subprocess.STDOUT, cwd=path).communicate()
+ except WindowsError:
+ # git is not available, skip this test.
+ return False
+ subprocess.Popen(['git', 'fast-import'], stdin=subprocess.PIPE,
+ stdout=subprocess.PIPE, stderr=subprocess.STDOUT,
+ cwd=path).communicate(input=git_import)
+ subprocess.Popen(['git', 'checkout'], stdout=subprocess.PIPE,
+ stderr=subprocess.STDOUT, cwd=path).communicate()
+ return True
+
+ def setUp(self):
+ BaseSCMTestCase.setUp(self)
+ self.args = self.Args()
+ self.url = 'git://foo'
+ self.root_dir = tempfile.mkdtemp()
+ self.relpath = '.'
+ self.base_path = os.path.join(self.root_dir, self.relpath)
+ self.enabled = self.CreateGitRepo(self.sample_git_import, self.base_path)
+
+ def tearDown(self):
+ shutil.rmtree(self.root_dir)
+ gclient_test.BaseTestCase.tearDown(self)
+
+
+class SVNTestCase(BaseSCMTestCase):
+ def setUp(self):
+ BaseSCMTestCase.setUp(self)
+ self.root_dir = self.Dir()
+ self.args = self.Args()
+ self.url = self.Url()
+ self.relpath = 'asf'
+
+ def testGetSVNFileInfo(self):
+ xml_text = r"""<?xml version="1.0"?>
+<info>
+<entry kind="file" path="%s" revision="14628">
+<url>http://src.chromium.org/svn/trunk/src/chrome/app/d</url>
+<repository><root>http://src.chromium.org/svn</root></repository>
+<wc-info>
+<schedule>add</schedule>
+<depth>infinity</depth>
+<copy-from-url>http://src.chromium.org/svn/trunk/src/chrome/app/DEPS</copy-from-url>
+<copy-from-rev>14628</copy-from-rev>
+<checksum>369f59057ba0e6d9017e28f8bdfb1f43</checksum>
+</wc-info>
+</entry>
+</info>
+""" % self.url
+ self.mox.StubOutWithMock(scm, 'CaptureSVN')
+ scm.CaptureSVN(['info', '--xml', self.url], '.', True).AndReturn(xml_text)
+ expected = {
+ 'URL': 'http://src.chromium.org/svn/trunk/src/chrome/app/d',
+ 'UUID': None,
+ 'Repository Root': 'http://src.chromium.org/svn',
+ 'Schedule': 'add',
+ 'Copied From URL':
+ 'http://src.chromium.org/svn/trunk/src/chrome/app/DEPS',
+ 'Copied From Rev': '14628',
+ 'Path': self.url,
+ 'Revision': 14628,
+ 'Node Kind': 'file',
+ }
+ self.mox.ReplayAll()
+ file_info = scm.CaptureSVNInfo(self.url, '.', True)
+ self.assertEquals(sorted(file_info.items()), sorted(expected.items()))
+
+ def testCaptureSvnInfo(self):
+ 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)
+ self.mox.StubOutWithMock(scm, 'CaptureSVN')
+ scm.CaptureSVN(['info', '--xml', self.url], '.', True).AndReturn(xml_text)
+ self.mox.ReplayAll()
+ file_info = scm.CaptureSVNInfo(self.url, '.', True)
+ expected = {
+ 'URL': self.url,
+ 'UUID': '7b9385f5-0452-0410-af26-ad4892b7a1fb',
+ 'Revision': 35,
+ 'Repository Root': self.root_dir,
+ 'Schedule': 'normal',
+ 'Copied From URL': None,
+ 'Copied From Rev': None,
+ 'Path': '.',
+ 'Node Kind': 'dir',
+ }
+ self.assertEqual(file_info, expected)
+
+ def testCaptureSVNStatus(self):
+ text =r"""<?xml version="1.0"?>
+<status>
+<target path=".">
+<entry path="unversionned_file.txt">
+<wc-status props="none" item="unversioned"></wc-status>
+</entry>
+<entry path="build\internal\essential.vsprops">
+<wc-status props="normal" item="modified" revision="14628">
+<commit revision="13818">
+<author>ajwong@chromium.org</author>
+<date>2009-04-16T00:42:06.872358Z</date>
+</commit>
+</wc-status>
+</entry>
+<entry path="chrome\app\d">
+<wc-status props="none" copied="true" tree-conflicted="true" item="added">
+</wc-status>
+</entry>
+<entry path="chrome\app\DEPS">
+<wc-status props="modified" item="modified" revision="14628">
+<commit revision="1279">
+<author>brettw@google.com</author>
+<date>2008-08-23T17:16:42.090152Z</date>
+</commit>
+</wc-status>
+</entry>
+<entry path="scripts\master\factory\gclient_factory.py">
+<wc-status props="normal" item="conflicted" revision="14725">
+<commit revision="14633">
+<author>nsylvain@chromium.org</author>
+<date>2009-04-27T19:37:17.977400Z</date>
+</commit>
+</wc-status>
+</entry>
+</target>
+</status>
+"""
+ proc = self.mox.CreateMockAnything()
+ scm.subprocess.Popen(['svn', 'status', '--xml', '.'],
+ cwd=None,
+ shell=scm.sys.platform.startswith('win'),
+ stderr=None,
+ stdout=scm.subprocess.PIPE).AndReturn(proc)
+ proc.communicate().AndReturn((text, 0))
+
+ self.mox.ReplayAll()
+ info = scm.CaptureSVNStatus('.')
+ expected = [
+ ('? ', 'unversionned_file.txt'),
+ ('M ', 'build\\internal\\essential.vsprops'),
+ ('A + ', 'chrome\\app\\d'),
+ ('MM ', 'chrome\\app\\DEPS'),
+ ('C ', 'scripts\\master\\factory\\gclient_factory.py'),
+ ]
+ self.assertEquals(sorted(info), sorted(expected))
+
+ def testRunSVN(self):
+ param2 = 'bleh'
+ scm.gclient_utils.SubprocessCall(['svn', 'foo', 'bar'],
+ param2).AndReturn(None)
+ self.mox.ReplayAll()
+ scm.RunSVN(['foo', 'bar'], param2)
+
+ def testCaptureSVNStatusEmpty(self):
+ text = r"""<?xml version="1.0"?>
+ <status>
+ <target
+ path="perf">
+ </target>
+ </status>"""
+ proc = self.mox.CreateMockAnything()
+ scm.subprocess.Popen(['svn', 'status', '--xml'],
+ cwd=None,
+ shell=scm.sys.platform.startswith('win'),
+ stderr=None,
+ stdout=scm.subprocess.PIPE).AndReturn(proc)
+ proc.communicate().AndReturn((text, 0))
+ self.mox.ReplayAll()
+ info = scm.CaptureSVNStatus(None)
+ self.assertEquals(info, [])
+
+
+if __name__ == '__main__':
+ import unittest
+ unittest.main()
+
+# vim: ts=2:sw=2:tw=80:et:
« no previous file with comments | « tests/gclient_test.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698