mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-25 08:59:31 -05:00
Properly migrate target branch change GitLab comment (#29340)
GitLab generates "system notes" whenever an event happens within the
platform. Unlike Gitea, those events are stored and retrieved as text
comments with no semantic details. The only way to tell whether a
comment was generated in this manner is the `system` flag on the note
type.
This PR adds detection for a new specific kind of event: Changing the
target branch of a PR. When detected, it is downloaded using Gitea's
type for this event, and eventually uploaded into Gitea in the expected
format, i.e. with no text content in the comment.
This PR also updates the template used to render comments to add support
for migrated comments of this type.
ref:
11bd6dc826/app/services/system_notes/merge_requests_service.rb (L102)
(cherry picked from commit 6e5966597c2d498d1a8540dad965461d44ff8e57)
This commit is contained in:
parent
6905540088
commit
f0acc71ba1
4 changed files with 50 additions and 8 deletions
|
@ -492,10 +492,16 @@ func (g *GiteaLocalUploader) CreateComments(comments ...*base.Comment) error {
|
||||||
}
|
}
|
||||||
case issues_model.CommentTypeChangeTitle:
|
case issues_model.CommentTypeChangeTitle:
|
||||||
if comment.Meta["OldTitle"] != nil {
|
if comment.Meta["OldTitle"] != nil {
|
||||||
cm.OldTitle = fmt.Sprintf("%s", comment.Meta["OldTitle"])
|
cm.OldTitle = fmt.Sprint(comment.Meta["OldTitle"])
|
||||||
}
|
}
|
||||||
if comment.Meta["NewTitle"] != nil {
|
if comment.Meta["NewTitle"] != nil {
|
||||||
cm.NewTitle = fmt.Sprintf("%s", comment.Meta["NewTitle"])
|
cm.NewTitle = fmt.Sprint(comment.Meta["NewTitle"])
|
||||||
|
}
|
||||||
|
case issues_model.CommentTypeChangeTargetBranch:
|
||||||
|
if comment.Meta["OldRef"] != nil && comment.Meta["NewRef"] != nil {
|
||||||
|
cm.OldRef = fmt.Sprint(comment.Meta["OldRef"])
|
||||||
|
cm.NewRef = fmt.Sprint(comment.Meta["NewRef"])
|
||||||
|
cm.Content = ""
|
||||||
}
|
}
|
||||||
case issues_model.CommentTypePRScheduledToAutoMerge, issues_model.CommentTypePRUnScheduledToAutoMerge:
|
case issues_model.CommentTypePRScheduledToAutoMerge, issues_model.CommentTypePRUnScheduledToAutoMerge:
|
||||||
cm.Content = ""
|
cm.Content = ""
|
||||||
|
|
|
@ -11,6 +11,7 @@ import (
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"path"
|
"path"
|
||||||
|
"regexp"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -519,6 +520,8 @@ func (g *GitlabDownloader) GetComments(commentable base.Commentable) ([]*base.Co
|
||||||
return allComments, true, nil
|
return allComments, true, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var targetBranchChangeRegexp = regexp.MustCompile("^changed target branch from `(.*?)` to `(.*?)`$")
|
||||||
|
|
||||||
func (g *GitlabDownloader) convertNoteToComment(localIndex int64, note *gitlab.Note) *base.Comment {
|
func (g *GitlabDownloader) convertNoteToComment(localIndex int64, note *gitlab.Note) *base.Comment {
|
||||||
comment := &base.Comment{
|
comment := &base.Comment{
|
||||||
IssueIndex: localIndex,
|
IssueIndex: localIndex,
|
||||||
|
@ -528,11 +531,16 @@ func (g *GitlabDownloader) convertNoteToComment(localIndex int64, note *gitlab.N
|
||||||
PosterEmail: note.Author.Email,
|
PosterEmail: note.Author.Email,
|
||||||
Content: note.Body,
|
Content: note.Body,
|
||||||
Created: *note.CreatedAt,
|
Created: *note.CreatedAt,
|
||||||
|
Meta: map[string]any{},
|
||||||
}
|
}
|
||||||
|
|
||||||
// Try to find the underlying event of system notes.
|
// Try to find the underlying event of system notes.
|
||||||
if note.System {
|
if note.System {
|
||||||
if strings.HasPrefix(note.Body, "enabled an automatic merge") {
|
if match := targetBranchChangeRegexp.FindStringSubmatch(note.Body); match != nil {
|
||||||
|
comment.CommentType = issues_model.CommentTypeChangeTargetBranch.String()
|
||||||
|
comment.Meta["OldRef"] = match[1]
|
||||||
|
comment.Meta["NewRef"] = match[2]
|
||||||
|
} else if strings.HasPrefix(note.Body, "enabled an automatic merge") {
|
||||||
comment.CommentType = issues_model.CommentTypePRScheduledToAutoMerge.String()
|
comment.CommentType = issues_model.CommentTypePRScheduledToAutoMerge.String()
|
||||||
} else if note.Body == "canceled the automatic merge" {
|
} else if note.Body == "canceled the automatic merge" {
|
||||||
comment.CommentType = issues_model.CommentTypePRUnScheduledToAutoMerge.String()
|
comment.CommentType = issues_model.CommentTypePRUnScheduledToAutoMerge.String()
|
||||||
|
|
|
@ -586,7 +586,8 @@ func TestNoteToComment(t *testing.T) {
|
||||||
notes := []gitlab.Note{
|
notes := []gitlab.Note{
|
||||||
makeTestNote(1, "This is a regular comment", false),
|
makeTestNote(1, "This is a regular comment", false),
|
||||||
makeTestNote(2, "enabled an automatic merge for abcd1234", true),
|
makeTestNote(2, "enabled an automatic merge for abcd1234", true),
|
||||||
makeTestNote(3, "canceled the automatic merge", true),
|
makeTestNote(3, "changed target branch from `master` to `main`", true),
|
||||||
|
makeTestNote(4, "canceled the automatic merge", true),
|
||||||
}
|
}
|
||||||
comments := []base.Comment{{
|
comments := []base.Comment{{
|
||||||
IssueIndex: 17,
|
IssueIndex: 17,
|
||||||
|
@ -597,6 +598,7 @@ func TestNoteToComment(t *testing.T) {
|
||||||
CommentType: "",
|
CommentType: "",
|
||||||
Content: "This is a regular comment",
|
Content: "This is a regular comment",
|
||||||
Created: now,
|
Created: now,
|
||||||
|
Meta: map[string]any{},
|
||||||
}, {
|
}, {
|
||||||
IssueIndex: 17,
|
IssueIndex: 17,
|
||||||
Index: 2,
|
Index: 2,
|
||||||
|
@ -606,15 +608,30 @@ func TestNoteToComment(t *testing.T) {
|
||||||
CommentType: "pull_scheduled_merge",
|
CommentType: "pull_scheduled_merge",
|
||||||
Content: "enabled an automatic merge for abcd1234",
|
Content: "enabled an automatic merge for abcd1234",
|
||||||
Created: now,
|
Created: now,
|
||||||
|
Meta: map[string]any{},
|
||||||
}, {
|
}, {
|
||||||
IssueIndex: 17,
|
IssueIndex: 17,
|
||||||
Index: 3,
|
Index: 3,
|
||||||
PosterID: 72,
|
PosterID: 72,
|
||||||
PosterName: "test",
|
PosterName: "test",
|
||||||
PosterEmail: "test@example.com",
|
PosterEmail: "test@example.com",
|
||||||
|
CommentType: "change_target_branch",
|
||||||
|
Content: "changed target branch from `master` to `main`",
|
||||||
|
Created: now,
|
||||||
|
Meta: map[string]any{
|
||||||
|
"OldRef": "master",
|
||||||
|
"NewRef": "main",
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
IssueIndex: 17,
|
||||||
|
Index: 4,
|
||||||
|
PosterID: 72,
|
||||||
|
PosterName: "test",
|
||||||
|
PosterEmail: "test@example.com",
|
||||||
CommentType: "pull_cancel_scheduled_merge",
|
CommentType: "pull_cancel_scheduled_merge",
|
||||||
Content: "canceled the automatic merge",
|
Content: "canceled the automatic merge",
|
||||||
Created: now,
|
Created: now,
|
||||||
|
Meta: map[string]any{},
|
||||||
}}
|
}}
|
||||||
|
|
||||||
for i, note := range notes {
|
for i, note := range notes {
|
||||||
|
|
|
@ -369,8 +369,7 @@
|
||||||
{{else if eq .Type 22}}
|
{{else if eq .Type 22}}
|
||||||
<div class="timeline-item-group" id="{{.HashTag}}">
|
<div class="timeline-item-group" id="{{.HashTag}}">
|
||||||
<div class="timeline-item event">
|
<div class="timeline-item event">
|
||||||
{{if .OriginalAuthor}}
|
{{if not .OriginalAuthor}}
|
||||||
{{else}}
|
|
||||||
{{/* Some timeline avatars need a offset to correctly align with their speech
|
{{/* Some timeline avatars need a offset to correctly align with their speech
|
||||||
bubble. The condition depends on review type and for positive reviews whether
|
bubble. The condition depends on review type and for positive reviews whether
|
||||||
there is a comment element or not */}}
|
there is a comment element or not */}}
|
||||||
|
@ -499,9 +498,21 @@
|
||||||
{{else if eq .Type 25}}
|
{{else if eq .Type 25}}
|
||||||
<div class="timeline-item event">
|
<div class="timeline-item event">
|
||||||
<span class="badge">{{svg "octicon-git-branch"}}</span>
|
<span class="badge">{{svg "octicon-git-branch"}}</span>
|
||||||
{{template "shared/user/avatarlink" dict "user" .Poster}}
|
{{if not .OriginalAuthor}}
|
||||||
|
{{template "shared/user/avatarlink" dict "user" .Poster}}
|
||||||
|
{{end}}
|
||||||
<span class="text grey muted-links">
|
<span class="text grey muted-links">
|
||||||
<a{{if gt .Poster.ID 0}} href="{{.Poster.HomeLink}}"{{end}}>{{.Poster.Name}}</a>
|
{{if .OriginalAuthor}}
|
||||||
|
<span class="text black">
|
||||||
|
{{svg (MigrationIcon $.Repository.GetOriginalURLHostname)}}
|
||||||
|
{{.OriginalAuthor}}
|
||||||
|
</span>
|
||||||
|
{{if $.Repository.OriginalURL}}
|
||||||
|
<span class="migrate">({{ctx.Locale.Tr "repo.migrated_from" $.Repository.OriginalURL $.Repository.GetOriginalURLHostname}})</span>
|
||||||
|
{{end}}
|
||||||
|
{{else}}
|
||||||
|
{{template "shared/user/authorlink" .Poster}}
|
||||||
|
{{end}}
|
||||||
{{ctx.Locale.Tr "repo.pulls.change_target_branch_at" (.OldRef|Escape) (.NewRef|Escape) $createdStr}}
|
{{ctx.Locale.Tr "repo.pulls.change_target_branch_at" (.OldRef|Escape) (.NewRef|Escape) $createdStr}}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue