Commit 053213d0 authored by Derek Morris's avatar Derek Morris Committed by LUCI CQ

Add a pan-project presubmit check for commits in tree

It's possible to add commit objects to the tree, and this can cause
some confusion for git's tools - if this happens to overlap with an
actual folder or a gclient-imported repo, the tree will be dirty.

This change finds this issue by scanning the tree and looking for a
commit object there.

Bug: 869594
Change-Id: Ia1f1fb22ab8f7ac1eed7b32dedad5c1296b1d67b
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/tools/depot_tools/+/1842637Reviewed-by: 's avatarDirk Pranke <dpranke@chromium.org>
Commit-Queue: Derek Morris <demorri@microsoft.com>
parent 30ef5cb4
...@@ -1222,6 +1222,10 @@ def PanProjectChecks(input_api, output_api, ...@@ -1222,6 +1222,10 @@ def PanProjectChecks(input_api, output_api,
snapshot("checking do not submit in files") snapshot("checking do not submit in files")
results.extend(input_api.canned_checks.CheckDoNotSubmitInFiles( results.extend(input_api.canned_checks.CheckDoNotSubmitInFiles(
input_api, output_api)) input_api, output_api))
if input_api.change.scm == 'git':
snapshot("checking for commit objects in tree")
results.extend(input_api.canned_checks.CheckForCommitObjects(
input_api, output_api))
snapshot("done") snapshot("done")
return results return results
...@@ -1384,6 +1388,57 @@ def CheckCIPDClientDigests(input_api, output_api, client_version_file): ...@@ -1384,6 +1388,57 @@ def CheckCIPDClientDigests(input_api, output_api, client_version_file):
output_api.PresubmitError) output_api.PresubmitError)
def CheckForCommitObjects(input_api, output_api):
"""Validates that there are no commit objects in the repository.
Commit objects are put into the git tree typically by submodule tooling.
Because we use gclient to handle external repository references instead,
we want to avoid this. Having commit objects in the tree can confuse git
tooling in some scenarios into thinking that the tree is dirty (e.g. the
presence of a DEPS subrepo at a location where a commit object is stored
in the tree).
Args:
input_api: Bag of input related interfaces.
output_api: Bag of output related interfaces.
Returns:
A presubmit error if a commit object is present in the tree.
"""
def parse_tree_entry(ent):
"""Splits a tree entry into components
Args:
ent: a tree entry in the form "filemode type hash\tname"
Returns:
The tree entry split into component parts
"""
tabparts = ent.split('\t', 1)
spaceparts = tabparts[0].split(' ', 2)
return (spaceparts[0], spaceparts[1], spaceparts[2], tabparts[1])
full_tree = input_api.subprocess.check_output(
['git', 'ls-tree', '-r', '--full-tree', 'HEAD'],
cwd=input_api.PresubmitLocalPath()
)
tree_entries = full_tree.split('\n')
tree_entries = filter(lambda x: len(x) > 0, tree_entries)
tree_entries = map(parse_tree_entry, tree_entries)
bad_tree_entries = filter(lambda x: x[1] == 'commit', tree_entries)
bad_tree_entries = map(lambda x: x[3], bad_tree_entries)
if len(bad_tree_entries) > 0:
return [output_api.PresubmitError(
'Commit objects present within tree.\n'
'This may be due to submodule-related interactions; the presence of a\n'
'commit object in the tree may lead to odd situations where files are\n'
'inconsistently checked-out. Remove these commit entries and validate\n'
'your changeset again:\n',
bad_tree_entries)]
return []
def CheckVPythonSpec(input_api, output_api, file_filter=None): def CheckVPythonSpec(input_api, output_api, file_filter=None):
"""Validates any changed .vpython files with vpython verification tool. """Validates any changed .vpython files with vpython verification tool.
......
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