Commit 8678d329 authored by Aaron Gable's avatar Aaron Gable Committed by Commit Bot

Disallow TBRs to OWNERS files

TBRs bypass owners checks, but are also semi-suspicious: a
contributor TBRing many changes in a row to submit code to
a directory they don't own would be seen, frowned upon, and
inquired into. However, a contributor could bypass this by
simply TBRing a single change to add themselves to an OWNERS
file, and then contributing as normal from there. This CL
removes that loophole.

This will not affect sheriffs who TBR reverts for two reasons:
first, it is rare that a chance touches both code and an
OWNERS file, and therefore it is rare that OWNERS changes
get reverted; second, quick reverts (the kind sheriffs do)
bypass PRESUBMIT entirely, and therefore also skip OWNERS
checks.

Bug: 688115
Change-Id: If2b5c9d058c62caf95389287e0bb706aef721baf
Reviewed-on: https://chromium-review.googlesource.com/982601
Commit-Queue: Aaron Gable <agable@chromium.org>
Reviewed-by: 's avatarEdward Lesmes <ehmaldonado@chromium.org>
Reviewed-by: 's avatarDirk Pranke <dpranke@chromium.org>
parent fb28d48c
......@@ -827,8 +827,11 @@ def CheckBuildbotPendingBuilds(input_api, output_api, url, max_pendings,
def CheckOwners(input_api, output_api, source_file_filter=None):
affected_files = set([f.LocalPath() for f in
input_api.change.AffectedFiles(file_filter=source_file_filter)])
if input_api.is_committing:
if input_api.tbr:
if input_api.tbr and not any(['OWNERS' in name for name in affected_files]):
return [output_api.PresubmitNotifyResult(
'--tbr was specified, skipping OWNERS check')]
needed = 'LGTM from an OWNER'
......@@ -846,9 +849,6 @@ def CheckOwners(input_api, output_api, source_file_filter=None):
needed = 'OWNER reviewers'
output_fn = output_api.PresubmitNotifyResult
affected_files = set([f.LocalPath() for f in
input_api.change.AffectedFiles(file_filter=source_file_filter)])
owners_db = input_api.owners_db
owners_db.override_files = input_api.change.OriginalOwnersFiles()
owner_email, reviewers = GetCodereviewOwnerAndReviewers(
......
......@@ -2398,9 +2398,9 @@ class CannedChecksUnittest(PresubmitTestsBase):
presubmit.OutputApi.PresubmitNotifyResult)
def AssertOwnersWorks(self, tbr=False, issue='1', approvers=None,
reviewers=None, is_committing=True,
response=None, uncovered_files=None, expected_output='',
manually_specified_reviewers=None, dry_run=None):
reviewers=None, is_committing=True, response=None, uncovered_files=None,
expected_output='', manually_specified_reviewers=None, dry_run=None,
modified_file='foo/xyz.cc'):
if approvers is None:
# The set of people who lgtm'ed a change.
approvers = set()
......@@ -2438,9 +2438,9 @@ class CannedChecksUnittest(PresubmitTestsBase):
input_api.tbr = tbr
input_api.dry_run = dry_run
if not is_committing or (not tbr and issue):
affected_file.LocalPath().AndReturn('foo/xyz.cc')
affected_file.LocalPath().AndReturn(modified_file)
change.AffectedFiles(file_filter=None).AndReturn([affected_file])
if not is_committing or (not tbr and issue) or ('OWNERS' in modified_file):
change.OriginalOwnersFiles().AndReturn({})
if issue and not response:
response = {
......@@ -2721,6 +2721,13 @@ class CannedChecksUnittest(PresubmitTestsBase):
expected_output='--tbr was specified, skipping OWNERS check\n')
self.AssertOwnersWorks(tbr=True, is_committing=False, expected_output='')
def testCannedCheckOwners_TBROWNERSFile(self):
self.AssertOwnersWorks(
tbr=True, uncovered_files=set(['foo']),
modified_file='foo/OWNERS',
expected_output='Missing LGTM from an OWNER for these files:\n'
' foo\n')
def testCannedCheckOwners_WithoutOwnerLGTM(self):
self.AssertOwnersWorks(uncovered_files=set(['foo']),
expected_output='Missing LGTM from an OWNER for these files:\n'
......
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