summaryrefslogtreecommitdiffstats
path: root/services/migrations
diff options
context:
space:
mode:
authorSebastian Brückner <mail@invlid.com>2023-10-29 01:54:58 +0100
committerGitHub <noreply@github.com>2023-10-29 00:54:58 +0000
commit8faa38568bd376c3c0f23a365302b646cf62f4b8 (patch)
treef694fb7074b6e4cc7973c84d68ee1d92db45b2cc /services/migrations
parent5a76759c9ca7a1ff49b9297b57cde1bd1586c4fe (diff)
downloadgitea-8faa38568bd376c3c0f23a365302b646cf62f4b8.tar.gz
gitea-8faa38568bd376c3c0f23a365302b646cf62f4b8.zip
Use GitLab's squash_commit_sha when available (#27824)
Before this PR, the PR migration code populates Gitea's MergedCommitID field by using GitLab's merge_commit_sha field. However, that field is only populated when the PR was merged using a merge strategy. When a squash strategy is used, squash_commit_sha is populated instead. Given that Gitea does not keep track of merge and squash commits separately, this PR simply populates Gitea's MergedCommitID by using whichever field is present in the GitLab API response.
Diffstat (limited to 'services/migrations')
-rw-r--r--services/migrations/gitlab.go7
1 files changed, 6 insertions, 1 deletions
diff --git a/services/migrations/gitlab.go b/services/migrations/gitlab.go
index f626036254..53540899a6 100644
--- a/services/migrations/gitlab.go
+++ b/services/migrations/gitlab.go
@@ -566,6 +566,11 @@ func (g *GitlabDownloader) GetPullRequests(page, perPage int) ([]*base.PullReque
closeTime = pr.UpdatedAt
}
+ mergeCommitSHA := pr.MergeCommitSHA
+ if mergeCommitSHA == "" {
+ mergeCommitSHA = pr.SquashCommitSHA
+ }
+
var locked bool
if pr.State == "locked" {
locked = true
@@ -608,7 +613,7 @@ func (g *GitlabDownloader) GetPullRequests(page, perPage int) ([]*base.PullReque
Closed: closeTime,
Labels: labels,
Merged: merged,
- MergeCommitSHA: pr.MergeCommitSHA,
+ MergeCommitSHA: mergeCommitSHA,
MergedTime: mergeTime,
IsLocked: locked,
Reactions: g.awardsToReactions(reactions),