mirror of
https://github.com/go-gitea/gitea.git
synced 2025-06-21 13:57:53 +00:00
Always use an empty line to separate the commit message and trailer (#34512)
If the message from form.MergeMessageField is empty, we will miss a "\n" between the title and the "Co-authored-by:" line. The title and message should have a blank line between of them. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
parent
74858dc5ae
commit
82ea2387e4
@ -13,6 +13,7 @@ import (
|
|||||||
"regexp"
|
"regexp"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"unicode"
|
||||||
|
|
||||||
"code.gitea.io/gitea/models/db"
|
"code.gitea.io/gitea/models/db"
|
||||||
git_model "code.gitea.io/gitea/models/git"
|
git_model "code.gitea.io/gitea/models/git"
|
||||||
@ -161,6 +162,41 @@ func GetDefaultMergeMessage(ctx context.Context, baseGitRepo *git.Repository, pr
|
|||||||
return getMergeMessage(ctx, baseGitRepo, pr, mergeStyle, nil)
|
return getMergeMessage(ctx, baseGitRepo, pr, mergeStyle, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func AddCommitMessageTailer(message, tailerKey, tailerValue string) string {
|
||||||
|
tailerLine := tailerKey + ": " + tailerValue
|
||||||
|
message = strings.ReplaceAll(message, "\r\n", "\n")
|
||||||
|
message = strings.ReplaceAll(message, "\r", "\n")
|
||||||
|
if strings.Contains(message, "\n"+tailerLine+"\n") || strings.HasSuffix(message, "\n"+tailerLine) {
|
||||||
|
return message
|
||||||
|
}
|
||||||
|
|
||||||
|
if !strings.HasSuffix(message, "\n") {
|
||||||
|
message += "\n"
|
||||||
|
}
|
||||||
|
pos1 := strings.LastIndexByte(message[:len(message)-1], '\n')
|
||||||
|
pos2 := -1
|
||||||
|
if pos1 != -1 {
|
||||||
|
pos2 = strings.IndexByte(message[pos1:], ':')
|
||||||
|
if pos2 != -1 {
|
||||||
|
pos2 += pos1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var lastLineKey string
|
||||||
|
if pos1 != -1 && pos2 != -1 {
|
||||||
|
lastLineKey = message[pos1+1 : pos2]
|
||||||
|
}
|
||||||
|
|
||||||
|
isLikelyTailerLine := lastLineKey != "" && unicode.IsUpper(rune(lastLineKey[0])) && strings.Contains(message, "-")
|
||||||
|
for i := 0; isLikelyTailerLine && i < len(lastLineKey); i++ {
|
||||||
|
r := rune(lastLineKey[i])
|
||||||
|
isLikelyTailerLine = unicode.IsLetter(r) || unicode.IsDigit(r) || r == '-'
|
||||||
|
}
|
||||||
|
if !strings.HasSuffix(message, "\n\n") && !isLikelyTailerLine {
|
||||||
|
message += "\n"
|
||||||
|
}
|
||||||
|
return message + tailerLine
|
||||||
|
}
|
||||||
|
|
||||||
// ErrInvalidMergeStyle represents an error if merging with disabled merge strategy
|
// ErrInvalidMergeStyle represents an error if merging with disabled merge strategy
|
||||||
type ErrInvalidMergeStyle struct {
|
type ErrInvalidMergeStyle struct {
|
||||||
ID int64
|
ID int64
|
||||||
|
@ -5,7 +5,6 @@ package pull
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
|
||||||
|
|
||||||
repo_model "code.gitea.io/gitea/models/repo"
|
repo_model "code.gitea.io/gitea/models/repo"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
@ -66,10 +65,8 @@ func doMergeStyleSquash(ctx *mergeContext, message string) error {
|
|||||||
|
|
||||||
if setting.Repository.PullRequest.AddCoCommitterTrailers && ctx.committer.String() != sig.String() {
|
if setting.Repository.PullRequest.AddCoCommitterTrailers && ctx.committer.String() != sig.String() {
|
||||||
// add trailer
|
// add trailer
|
||||||
if !strings.Contains(message, "Co-authored-by: "+sig.String()) {
|
message = AddCommitMessageTailer(message, "Co-authored-by", sig.String())
|
||||||
message += "\nCo-authored-by: " + sig.String()
|
message = AddCommitMessageTailer(message, "Co-committed-by", sig.String()) // FIXME: this one should be removed, it is not really used or widely used
|
||||||
}
|
|
||||||
message += fmt.Sprintf("\nCo-committed-by: %s\n", sig.String())
|
|
||||||
}
|
}
|
||||||
cmdCommit := git.NewCommand("commit").
|
cmdCommit := git.NewCommand("commit").
|
||||||
AddOptionFormat("--author='%s <%s>'", sig.Name, sig.Email).
|
AddOptionFormat("--author='%s <%s>'", sig.Name, sig.Email).
|
||||||
|
@ -65,3 +65,28 @@ func Test_expandDefaultMergeMessage(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestAddCommitMessageTailer(t *testing.T) {
|
||||||
|
// add tailer for empty message
|
||||||
|
assert.Equal(t, "\n\nTest-tailer: TestValue", AddCommitMessageTailer("", "Test-tailer", "TestValue"))
|
||||||
|
|
||||||
|
// add tailer for message without newlines
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: TestValue", AddCommitMessageTailer("title", "Test-tailer", "TestValue"))
|
||||||
|
assert.Equal(t, "title\n\nNot tailer: xxx\n\nTest-tailer: TestValue", AddCommitMessageTailer("title\n\nNot tailer: xxx", "Test-tailer", "TestValue"))
|
||||||
|
assert.Equal(t, "title\n\nNotTailer: xxx\n\nTest-tailer: TestValue", AddCommitMessageTailer("title\n\nNotTailer: xxx", "Test-tailer", "TestValue"))
|
||||||
|
assert.Equal(t, "title\n\nnot-tailer: xxx\n\nTest-tailer: TestValue", AddCommitMessageTailer("title\n\nnot-tailer: xxx", "Test-tailer", "TestValue"))
|
||||||
|
|
||||||
|
// add tailer for message with one EOL
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: TestValue", AddCommitMessageTailer("title\n", "Test-tailer", "TestValue"))
|
||||||
|
|
||||||
|
// add tailer for message with two EOLs
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: TestValue", AddCommitMessageTailer("title\n\n", "Test-tailer", "TestValue"))
|
||||||
|
|
||||||
|
// add tailer for message with existing tailer (won't duplicate)
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: TestValue", AddCommitMessageTailer("title\n\nTest-tailer: TestValue", "Test-tailer", "TestValue"))
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: TestValue\n", AddCommitMessageTailer("title\n\nTest-tailer: TestValue\n", "Test-tailer", "TestValue"))
|
||||||
|
|
||||||
|
// add tailer for message with existing tailer and different value (will append)
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: v1\nTest-tailer: v2", AddCommitMessageTailer("title\n\nTest-tailer: v1", "Test-tailer", "v2"))
|
||||||
|
assert.Equal(t, "title\n\nTest-tailer: v1\nTest-tailer: v2", AddCommitMessageTailer("title\n\nTest-tailer: v1\n", "Test-tailer", "v2"))
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user