Merge branch 'stable-3.1'
* stable-3.1:
Update git submodules
Update git submodules
OperatingSystemMXBeanFactory: Add a default constructor
Remove unnecessary @SuppressWarnings("restriction")
Set version to 2.16.19-SNAPSHOT
Set version to 2.16.18
Update git submodules
Update git submodules
Update git submodules
Update git submodules
Add mirror for downloading Bazel rules.
Update git submodules
Upgrade JGit to v5.6.1.202002131546-r-19-ga79c5b1f1
Upgrade gwtjsonrpc to 1.12
CommitValidators: Use ImmutableList.Builder instead of ImmutableList.of
Update git submodules
Update git submodules
Update git submodules
Always verify PolyGerrit if bazel related files are changed
Always run all tests, if bazel-related files are changed
Fix implementation plan link in Contributing page
Add test that verifies 'visibleto' predicate for group
Make cache disk stat metric computation optional
ReceiveCommits: Log "update failed" at severe level
Revert "Insert Change-Id at start of trailers"
Revert "commit-msg: Remove obsolete comments"
Remove obsolete UpgradeFrom2_0_x init step
Update git submodules
Update git submodules
Add coverageRangeChanged to notify all related listeners
Improve documentation of change refs
Notify all coverage listeners when coverage data is available
Remove duplicate test method removeAnonymousRead
ChangeQueryBuilder: Use ChangeIsVisibleToPredicate.Factory
ChangeQueryProcessor: Use ChangeIsVisibleToPredicate.Factory
Make the build pipeline fail if cannot post Checks feedback
Switch to using no-AOP guice distribution
Bazel: Use canonical_id for artifacts cached by http_file
Fix for Memory leak in gr-plugin-endpoints
Documentation: Clarify how to log e2e http details
Make legacy version of the commit-msg hook available
Don't inject CurrentUser to ChangeIsVisibleToPredicate
HttpLogoutServlet: Test redirections with canonicalWebUrl set
commit-msg: Remove obsolete comments
Upgrade testcontainers to 1.14.0
Bump asm to version 7.2
Upgrade guice to 4.2.3
PostReview: Avoid multiple notifications for existing reviewers
ChangeApi: Remove deprecated getEdit method
ChangeApi: Remove useless @Deprecated annotation in NotImplemented
Plugin API: Remove deprecated draft workflow methods
ErrorProne: Enable ObjectToString check at ERROR severity
Project: Add implementation of toString
Allow HTTP {listen,canonicalWeb}Url in tests
Account: Add implementation of toString
LegacyChangeNoteWrite: Remove unused newIdent method
Update git submodules
PolyGerrit: Document commit-container extension endpoint
e2e-tests: Make all current scenario names unique
e2e-tests: Make http request name unique
e2e-tests: Fix CloneUsingBothProtocols wait times
e2e-tests: Create/delete ReplayRecordsFromFeeder project
e2e-tests: Unhardcode ReplayRecordsFromFeeder data
e2e-tests: Stabilize the ReplayRecordsFromFeeder scenario
Remove obsolete FindBugs configuration
Elasticsearch: Remove support for EOL 6.x versions
REST: Allow to create annotated tag with only CREATE_TAG
Upgrade recommended version of buildifier to 2.2.1
Bump Bazel version to 3.0.0
CreateRefControl: Pass CurrentUser to Reachable
Change-Id: I0d30560b4ee78393ef6f25166999529c88341273
This commit is contained in:
@@ -63,9 +63,9 @@ index 625fd613d9..03aeba3b21 100755
|
||||
@@ -38,6 +38,7 @@
|
||||
context
|
||||
line
|
||||
|
||||
|
||||
+hello, world
|
||||
|
||||
|
||||
context
|
||||
line
|
||||
EOF
|
||||
@@ -111,7 +111,7 @@ EOF
|
||||
}
|
||||
|
||||
# Change-Id goes after existing trailers.
|
||||
function test_at_start {
|
||||
function test_at_end {
|
||||
cat << EOF > input
|
||||
bla bla
|
||||
|
||||
@@ -119,16 +119,16 @@ Bug: #123
|
||||
EOF
|
||||
|
||||
${hook} input || fail "failed hook execution"
|
||||
result=$(git interpret-trailers --parse input | head -1 | grep ^Change-Id)
|
||||
result=$(tail -1 input | grep ^Change-Id)
|
||||
if [[ -z "${result}" ]] ; then
|
||||
echo "after: "
|
||||
cat input
|
||||
|
||||
fail "did not find Change-Id at start"
|
||||
fail "did not find Change-Id at end"
|
||||
fi
|
||||
}
|
||||
|
||||
function test_dash_at_start {
|
||||
function test_dash_at_end {
|
||||
if [[ ! -x /bin/dash ]] ; then
|
||||
echo "/bin/dash not installed; skipping dash test."
|
||||
return
|
||||
@@ -142,12 +142,12 @@ EOF
|
||||
|
||||
/bin/dash ${hook} input || fail "failed hook execution"
|
||||
|
||||
result=$(git interpret-trailers --parse input | head -1 | grep ^Change-Id)
|
||||
result=$(tail -1 input | grep ^Change-Id)
|
||||
if [[ -z "${result}" ]] ; then
|
||||
echo "after: "
|
||||
cat input
|
||||
|
||||
fail "did not find Change-Id at start"
|
||||
fail "did not find Change-Id at end"
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
@@ -5,4 +5,6 @@
|
||||
|
||||
755 hooks/commit-msg
|
||||
|
||||
755 hooks/commit-msg-legacy
|
||||
|
||||
755 scripts/reposize.sh
|
||||
|
||||
@@ -50,7 +50,7 @@ fi
|
||||
|
||||
# Avoid the --in-place option which only appeared in Git 2.8
|
||||
# Avoid the --if-exists option which only appeared in Git 2.15
|
||||
if ! git -c trailer.ifexists=doNothing interpret-trailers --where start \
|
||||
if ! git -c trailer.ifexists=doNothing interpret-trailers \
|
||||
--trailer "Change-Id: I${random}" < "$1" > "${dest}" ; then
|
||||
echo "cannot insert change-id line in $1"
|
||||
exit 1
|
||||
|
||||
193
resources/com/google/gerrit/server/tools/root/hooks/commit-msg-legacy
Executable file
193
resources/com/google/gerrit/server/tools/root/hooks/commit-msg-legacy
Executable file
@@ -0,0 +1,193 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# Part of Gerrit Code Review (https://www.gerritcodereview.com/)
|
||||
#
|
||||
# Copyright (C) 2009 The Android Open Source Project
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
#
|
||||
|
||||
unset GREP_OPTIONS
|
||||
|
||||
CHANGE_ID_AFTER="Bug|Depends-On|Issue|Test|Feature|Fixes|Fixed"
|
||||
MSG="$1"
|
||||
|
||||
# Check for, and add if missing, a unique Change-Id
|
||||
#
|
||||
add_ChangeId() {
|
||||
clean_message=`sed -e '
|
||||
/^diff --git .*/{
|
||||
s///
|
||||
q
|
||||
}
|
||||
/^Signed-off-by:/d
|
||||
/^#/d
|
||||
' "$MSG" | git stripspace`
|
||||
if test -z "$clean_message"
|
||||
then
|
||||
return
|
||||
fi
|
||||
|
||||
# Do not add Change-Id to temp commits
|
||||
if echo "$clean_message" | head -1 | grep -q '^\(fixup\|squash\)!'
|
||||
then
|
||||
return
|
||||
fi
|
||||
|
||||
if test "false" = "`git config --bool --get gerrit.createChangeId`"
|
||||
then
|
||||
return
|
||||
fi
|
||||
|
||||
# Does Change-Id: already exist? if so, exit (no change).
|
||||
if grep -i '^Change-Id:' "$MSG" >/dev/null
|
||||
then
|
||||
return
|
||||
fi
|
||||
|
||||
id=`_gen_ChangeId`
|
||||
T="$MSG.tmp.$$"
|
||||
AWK=awk
|
||||
if [ -x /usr/xpg4/bin/awk ]; then
|
||||
# Solaris AWK is just too broken
|
||||
AWK=/usr/xpg4/bin/awk
|
||||
fi
|
||||
|
||||
# Get core.commentChar from git config or use default symbol
|
||||
commentChar=`git config --get core.commentChar`
|
||||
commentChar=${commentChar:-#}
|
||||
|
||||
# How this works:
|
||||
# - parse the commit message as (textLine+ blankLine*)*
|
||||
# - assume textLine+ to be a footer until proven otherwise
|
||||
# - exception: the first block is not footer (as it is the title)
|
||||
# - read textLine+ into a variable
|
||||
# - then count blankLines
|
||||
# - once the next textLine appears, print textLine+ blankLine* as these
|
||||
# aren't footer
|
||||
# - in END, the last textLine+ block is available for footer parsing
|
||||
$AWK '
|
||||
BEGIN {
|
||||
if (match(ENVIRON["OS"], "Windows")) {
|
||||
RS="\r?\n" # Required on recent Cygwin
|
||||
}
|
||||
# while we start with the assumption that textLine+
|
||||
# is a footer, the first block is not.
|
||||
isFooter = 0
|
||||
footerComment = 0
|
||||
blankLines = 0
|
||||
}
|
||||
|
||||
# Skip lines starting with commentChar without any spaces before it.
|
||||
/^'"$commentChar"'/ { next }
|
||||
|
||||
# Skip the line starting with the diff command and everything after it,
|
||||
# up to the end of the file, assuming it is only patch data.
|
||||
# If more than one line before the diff was empty, strip all but one.
|
||||
/^diff --git / {
|
||||
blankLines = 0
|
||||
while (getline) { }
|
||||
next
|
||||
}
|
||||
|
||||
# Count blank lines outside footer comments
|
||||
/^$/ && (footerComment == 0) {
|
||||
blankLines++
|
||||
next
|
||||
}
|
||||
|
||||
# Catch footer comment
|
||||
/^\[[a-zA-Z0-9-]+:/ && (isFooter == 1) {
|
||||
footerComment = 1
|
||||
}
|
||||
|
||||
/]$/ && (footerComment == 1) {
|
||||
footerComment = 2
|
||||
}
|
||||
|
||||
# We have a non-blank line after blank lines. Handle this.
|
||||
(blankLines > 0) {
|
||||
print lines
|
||||
for (i = 0; i < blankLines; i++) {
|
||||
print ""
|
||||
}
|
||||
|
||||
lines = ""
|
||||
blankLines = 0
|
||||
isFooter = 1
|
||||
footerComment = 0
|
||||
}
|
||||
|
||||
# Detect that the current block is not the footer
|
||||
(footerComment == 0) && (!/^\[?[a-zA-Z0-9-]+:/ || /^[a-zA-Z0-9-]+:\/\//) {
|
||||
isFooter = 0
|
||||
}
|
||||
|
||||
{
|
||||
# We need this information about the current last comment line
|
||||
if (footerComment == 2) {
|
||||
footerComment = 0
|
||||
}
|
||||
if (lines != "") {
|
||||
lines = lines "\n";
|
||||
}
|
||||
lines = lines $0
|
||||
}
|
||||
|
||||
# Footer handling:
|
||||
# If the last block is considered a footer, splice in the Change-Id at the
|
||||
# right place.
|
||||
# Look for the right place to inject Change-Id by considering
|
||||
# CHANGE_ID_AFTER. Keys listed in it (case insensitive) come first,
|
||||
# then Change-Id, then everything else (eg. Signed-off-by:).
|
||||
#
|
||||
# Otherwise just print the last block, a new line and the Change-Id as a
|
||||
# block of its own.
|
||||
END {
|
||||
unprinted = 1
|
||||
if (isFooter == 0) {
|
||||
print lines "\n"
|
||||
lines = ""
|
||||
}
|
||||
changeIdAfter = "^(" tolower("'"$CHANGE_ID_AFTER"'") "):"
|
||||
numlines = split(lines, footer, "\n")
|
||||
for (line = 1; line <= numlines; line++) {
|
||||
if (unprinted && match(tolower(footer[line]), changeIdAfter) != 1) {
|
||||
unprinted = 0
|
||||
print "Change-Id: I'"$id"'"
|
||||
}
|
||||
print footer[line]
|
||||
}
|
||||
if (unprinted) {
|
||||
print "Change-Id: I'"$id"'"
|
||||
}
|
||||
}' "$MSG" > "$T" && mv "$T" "$MSG" || rm -f "$T"
|
||||
}
|
||||
_gen_ChangeIdInput() {
|
||||
echo "tree `git write-tree`"
|
||||
if parent=`git rev-parse "HEAD^0" 2>/dev/null`
|
||||
then
|
||||
echo "parent $parent"
|
||||
fi
|
||||
echo "author `git var GIT_AUTHOR_IDENT`"
|
||||
echo "committer `git var GIT_COMMITTER_IDENT`"
|
||||
echo
|
||||
printf '%s' "$clean_message"
|
||||
}
|
||||
_gen_ChangeId() {
|
||||
_gen_ChangeIdInput |
|
||||
git hash-object -t commit --stdin
|
||||
}
|
||||
|
||||
|
||||
add_ChangeId
|
||||
Reference in New Issue
Block a user