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

Unified Diff: tests/presubmit_unittest.py

Issue 6461011: Modify presubmit checks to work on changed lines only. (Closed)
Patch Set: Address review comments. Created 9 years, 10 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 side-by-side diff with in-line comments
Download patch
« presubmit_support.py ('K') | « presubmit_support.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/presubmit_unittest.py
diff --git a/tests/presubmit_unittest.py b/tests/presubmit_unittest.py
index d8f186b5cd3e75e510db31fcaa71ed22f1d3a30a..cc799fa9683586a4585826893ac17b8b421f2821 100755
--- a/tests/presubmit_unittest.py
+++ b/tests/presubmit_unittest.py
@@ -37,6 +37,47 @@ def GetPreferredTrySlaves():
return %s
"""
+ presubmit_diffs = """
+--- /tmp/file1 2011-02-08 21:35:31.998479201 -0800
++++ /tmp/file2 2011-02-08 21:36:50.487240201 -0800
+@@ -1,6 +1,5 @@
+ this is line number 0
+ this is line number 1
+-this is line number 2 to be deleted
+ this is line number 3
+ this is line number 4
+ this is line number 5
+@@ -8,7 +7,7 @@
+ this is line number 7
+ this is line number 8
+ this is line number 9
+-this is line number 10 to be modified
++this is line number 10
+ this is line number 11
+ this is line number 12
+ this is line number 13
+@@ -21,9 +20,8 @@
+ this is line number 20
+ this is line number 21
+ this is line number 22
+-this is line number 23
+-this is line number 24
+-this is line number 25
++this is line number 23.1
++this is line number 25.1
+ this is line number 26
+ this is line number 27
+ this is line number 28
+@@ -31,6 +29,7 @@
+ this is line number 30
+ this is line number 31
+ this is line number 32
++this is line number 32.1
M-A Ruel 2011/02/09 18:30:26 Add a + on a single line to verify my concern abou
vb 2011/02/09 18:54:11 Done.
+ this is line number 33
+ this is line number 34
+ this is line number 35
+"""
+
def setUp(self):
SuperMoxTestBase.setUp(self)
self.mox.StubOutWithMock(presubmit, 'random')
@@ -56,6 +97,7 @@ def GetPreferredTrySlaves():
self.mox.StubOutWithMock(presubmit.scm.SVN, 'GetFileProperty')
self.mox.StubOutWithMock(presubmit.gclient_utils, 'FileRead')
self.mox.StubOutWithMock(presubmit.gclient_utils, 'FileWrite')
+ self.mox.StubOutWithMock(presubmit.scm.SVN, 'GenerateDiff')
class PresubmitUnittest(PresubmitTestsBase):
@@ -197,8 +239,9 @@ class PresubmitUnittest(PresubmitTestsBase):
presubmit.scm.SVN.CaptureInfo(notfound).AndReturn({})
presubmit.scm.SVN.CaptureInfo(flap).AndReturn(
{'URL': 'svn:/foo/boo/flap.h'})
- presubmit.gclient_utils.FileRead(blat, 'rU').AndReturn('boo!\nahh?')
- presubmit.gclient_utils.FileRead(notfound, 'rU').AndReturn('look!\nthere?')
+ presubmit.scm.SVN.GenerateDiff(blat).AndReturn(self.presubmit_diffs)
+ presubmit.scm.SVN.GenerateDiff(notfound).AndReturn(self.presubmit_diffs)
+
self.mox.ReplayAll()
change = presubmit.SvnChange('mychange', '\n'.join(description_lines),
@@ -242,20 +285,20 @@ class PresubmitUnittest(PresubmitTestsBase):
for line in change.RightHandSideLines():
rhs_lines.append(line)
self.assertEquals(rhs_lines[0][0].LocalPath(), files[0][1])
- self.assertEquals(rhs_lines[0][1], 1)
- self.assertEquals(rhs_lines[0][2],'boo!')
+ self.assertEquals(rhs_lines[0][1], 10)
+ self.assertEquals(rhs_lines[0][2],'this is line number 10')
- self.assertEquals(rhs_lines[1][0].LocalPath(), files[0][1])
- self.assertEquals(rhs_lines[1][1], 2)
- self.assertEquals(rhs_lines[1][2], 'ahh?')
+ self.assertEquals(rhs_lines[3][0].LocalPath(), files[0][1])
+ self.assertEquals(rhs_lines[3][1], 32)
+ self.assertEquals(rhs_lines[3][2], 'this is line number 32.1')
- self.assertEquals(rhs_lines[2][0].LocalPath(), files[3][1])
- self.assertEquals(rhs_lines[2][1], 1)
- self.assertEquals(rhs_lines[2][2], 'look!')
+ self.assertEquals(rhs_lines[5][0].LocalPath(), files[3][1])
+ self.assertEquals(rhs_lines[5][1], 23)
+ self.assertEquals(rhs_lines[5][2], 'this is line number 23.1')
- self.assertEquals(rhs_lines[3][0].LocalPath(), files[3][1])
- self.assertEquals(rhs_lines[3][1], 2)
- self.assertEquals(rhs_lines[3][2], 'there?')
+ self.assertEquals(rhs_lines[6][0].LocalPath(), files[3][1])
+ self.assertEquals(rhs_lines[6][1], 24)
+ self.assertEquals(rhs_lines[6][2], 'this is line number 25.1')
def testExecPresubmitScript(self):
description_lines = ('Hello there',
@@ -711,10 +754,9 @@ class InputApiUnittest(PresubmitTestsBase):
presubmit.scm.SVN.GetFileProperty(another, 'svn:mime-type').AndReturn(None)
presubmit.scm.SVN.GetFileProperty(third_party, 'svn:mime-type'
).AndReturn(None)
- presubmit.gclient_utils.FileRead(blat, 'rU'
- ).AndReturn('whatever\ncookie')
- presubmit.gclient_utils.FileRead(another, 'rU'
- ).AndReturn('whatever\ncookie2')
+ presubmit.scm.SVN.GenerateDiff(blat).AndReturn(self.presubmit_diffs)
+ presubmit.scm.SVN.GenerateDiff(another).AndReturn(self.presubmit_diffs)
+
self.mox.ReplayAll()
change = presubmit.SvnChange('mychange', '\n'.join(description_lines),
@@ -737,14 +779,14 @@ class InputApiUnittest(PresubmitTestsBase):
# binary isn't a text file and beingdeleted doesn't exist. The rest is
# outside foo/.
rhs_lines = [x for x in input_api.RightHandSideLines(None)]
- self.assertEquals(len(rhs_lines), 4)
+ self.assertEquals(len(rhs_lines), 8)
self.assertEqual(rhs_lines[0][0].LocalPath(),
presubmit.normpath(files[0][1]))
- self.assertEqual(rhs_lines[1][0].LocalPath(),
+ self.assertEqual(rhs_lines[3][0].LocalPath(),
presubmit.normpath(files[0][1]))
- self.assertEqual(rhs_lines[2][0].LocalPath(),
+ self.assertEqual(rhs_lines[4][0].LocalPath(),
presubmit.normpath(files[4][1]))
- self.assertEqual(rhs_lines[3][0].LocalPath(),
+ self.assertEqual(rhs_lines[7][0].LocalPath(),
presubmit.normpath(files[4][1]))
def testDefaultWhiteListBlackListFilters(self):
@@ -1018,11 +1060,13 @@ class AffectedFileUnittest(PresubmitTestsBase):
def testMembersChanged(self):
self.mox.ReplayAll()
members = [
- 'AbsoluteLocalPath', 'Action', 'IsDirectory', 'IsTextFile', 'LocalPath',
- 'NewContents', 'OldContents', 'OldFileTempPath', 'Property', 'ServerPath',
+ 'AbsoluteLocalPath', 'Action', 'ChangedContents', 'IsDirectory',
+ 'IsTextFile', 'LocalPath', 'NewContents', 'OldContents',
+ 'OldFileTempPath', 'Property', 'ServerPath',
]
# If this test fails, you should add the relevant test.
self.compareMembers(presubmit.AffectedFile('a', 'b'), members)
+ members.append('GenerateScmDiff')
self.compareMembers(presubmit.SvnAffectedFile('a', 'b'), members)
def testAffectedFile(self):
« presubmit_support.py ('K') | « presubmit_support.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698