Remove stale revert.py unit test and fix another test I broke in r37487.
TEST=unit tests BUG=none Review URL: http://codereview.chromium.org/556092 git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@37618 0039d316-1c4b-4281-b951-d872f2087c98experimental/szager/collated-output
parent
5f423140ba
commit
56ca2c246c
@ -1,112 +0,0 @@
|
|||||||
#!/usr/bin/python
|
|
||||||
# Copyright (c) 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 revert.py."""
|
|
||||||
|
|
||||||
import revert
|
|
||||||
from super_mox import mox, SuperMoxTestBase
|
|
||||||
|
|
||||||
|
|
||||||
class RevertTestsBase(SuperMoxTestBase):
|
|
||||||
"""Setups and tear downs the mocks but doesn't test anything as-is."""
|
|
||||||
def setUp(self):
|
|
||||||
SuperMoxTestBase.setUp(self)
|
|
||||||
self.mox.StubOutWithMock(revert, 'gcl')
|
|
||||||
self.mox.StubOutWithMock(revert, 'gclient')
|
|
||||||
self.mox.StubOutWithMock(revert, 'gclient_scm')
|
|
||||||
|
|
||||||
# These functions are not tested.
|
|
||||||
self.mox.StubOutWithMock(revert, 'GetRepoBase')
|
|
||||||
self.mox.StubOutWithMock(revert, 'CaptureSVNLog')
|
|
||||||
|
|
||||||
|
|
||||||
class RevertUnittest(RevertTestsBase):
|
|
||||||
"""General revert.py tests."""
|
|
||||||
def testMembersChanged(self):
|
|
||||||
members = [
|
|
||||||
'CaptureSVNLog', 'GetRepoBase', 'Main', 'ModifiedFile', 'NoBlameList',
|
|
||||||
'NoModifiedFile', 'OutsideOfCheckout', 'Revert', 'UniqueFast',
|
|
||||||
'exceptions', 'gcl', 'gclient', 'gclient_scm', 'gclient_utils',
|
|
||||||
'optparse', 'os', 'sys', 'xml'
|
|
||||||
]
|
|
||||||
# If this test fails, you should add the relevant test.
|
|
||||||
self.compareMembers(revert, members)
|
|
||||||
|
|
||||||
|
|
||||||
class RevertMainUnittest(RevertTestsBase):
|
|
||||||
def setUp(self):
|
|
||||||
RevertTestsBase.setUp(self)
|
|
||||||
self.mox.StubOutWithMock(revert, 'gcl')
|
|
||||||
self.mox.StubOutWithMock(revert, 'Revert')
|
|
||||||
self.fake_root = '/revert/RevertMainUnittest/ShouldntExist'
|
|
||||||
|
|
||||||
def testMain(self):
|
|
||||||
# OptParser calls revert.os.path.exists and is a pain when mocked.
|
|
||||||
self.UnMock(revert.os.path, 'exists')
|
|
||||||
revert.gcl.GetInfoDir().AndReturn(self.fake_root)
|
|
||||||
#revert.os.path.exists(self.fake_root).AndReturn(True)
|
|
||||||
revert.os.mkdir(self.fake_root)
|
|
||||||
revert.gcl.GetInfoDir().AndReturn(self.fake_root)
|
|
||||||
revert.Revert([42, 23], True, True, False, 'bleh', ['foo@example.com']
|
|
||||||
).AndReturn(31337)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
self.assertEquals(revert.Main(['revert', '-c', '-f', '-n', '-m', 'bleh',
|
|
||||||
'-r', 'foo@example.com', '42', '23']),
|
|
||||||
31337)
|
|
||||||
|
|
||||||
|
|
||||||
class RevertRevertUnittest(RevertTestsBase):
|
|
||||||
def setUp(self):
|
|
||||||
RevertTestsBase.setUp(self)
|
|
||||||
self.mox.StubOutWithMock(revert.gclient_scm.scm.SVN, 'CaptureStatus')
|
|
||||||
|
|
||||||
def testRevert(self):
|
|
||||||
revert.gcl.GetRepositoryRoot().AndReturn('foo')
|
|
||||||
revert.os.chdir('foo')
|
|
||||||
entries = [{
|
|
||||||
'author': 'Georges',
|
|
||||||
'paths': [
|
|
||||||
{'path': 'proto://fqdn/repo/random_file'}
|
|
||||||
],
|
|
||||||
}]
|
|
||||||
revert.CaptureSVNLog(['-r', '42', '-v']).AndReturn(entries)
|
|
||||||
revert.GetRepoBase().AndReturn('proto://fqdn/repo/')
|
|
||||||
revert.gclient_scm.scm.SVN.CaptureStatus(['random_file']).AndReturn([])
|
|
||||||
revert.gcl.RunShell(['svn', 'up', 'random_file'])
|
|
||||||
revert.os.path.isdir('random_file').AndReturn(False)
|
|
||||||
status = """--- Reverse-merging r42 into '.':
|
|
||||||
M random_file
|
|
||||||
"""
|
|
||||||
revert.gcl.RunShellWithReturnCode(['svn', 'merge', '-c', '-42',
|
|
||||||
'random_file'],
|
|
||||||
print_output=True).AndReturn([status, 0])
|
|
||||||
change = self.mox.CreateMockAnything()
|
|
||||||
revert.gcl.ChangeInfo('revert42', 0, 0, 'Reverting 42.\n\nbleh',
|
|
||||||
[('M ', 'random_file')], 'foo').AndReturn(change)
|
|
||||||
change.Save()
|
|
||||||
revert.gcl.UploadCL(change,
|
|
||||||
['--no_presubmit', '-r', 'foo@example.com', '--no_try'])
|
|
||||||
revert.gcl.Commit(change, ['--no_presubmit', '--force'])
|
|
||||||
revert.gclient.Main(['gclient.py', 'sync'])
|
|
||||||
outputs = [
|
|
||||||
'Blaming Georges\n',
|
|
||||||
'Emailing foo@example.com\n',
|
|
||||||
'These files were modified in 42:',
|
|
||||||
'random_file',
|
|
||||||
'',
|
|
||||||
'Reverting 42 in ./'
|
|
||||||
]
|
|
||||||
for line in outputs:
|
|
||||||
revert.sys.stdout.write(line)
|
|
||||||
revert.sys.stdout.write('\n')
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
revert.Revert([42], True, True, False, 'bleh', ['foo@example.com'])
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
import unittest
|
|
||||||
unittest.main()
|
|
||||||
Loading…
Reference in New Issue