mirror of https://github.com/go-gitea/gitea
Move database operations of merging a pull request to post receive hook and add a transaction (#30805)
Merging PR may fail because of various problems. The pull request may have a dirty state because there is no transaction when merging a pull request. ref https://github.com/go-gitea/gitea/pull/25741#issuecomment-2074126393 This PR moves all database update operations to post-receive handler for merging a pull request and having a database transaction. That means if database operations fail, then the git merging will fail, the git client will get a fail result. There are already many tests for pull request merging, so we don't need to add a new one. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>pull/30885/head^2
parent
6ad77125ca
commit
ebf0c96940
@ -0,0 +1,49 @@ |
|||||||
|
// Copyright 2024 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package private |
||||||
|
|
||||||
|
import ( |
||||||
|
"testing" |
||||||
|
|
||||||
|
"code.gitea.io/gitea/models/db" |
||||||
|
issues_model "code.gitea.io/gitea/models/issues" |
||||||
|
pull_model "code.gitea.io/gitea/models/pull" |
||||||
|
repo_model "code.gitea.io/gitea/models/repo" |
||||||
|
"code.gitea.io/gitea/models/unittest" |
||||||
|
user_model "code.gitea.io/gitea/models/user" |
||||||
|
"code.gitea.io/gitea/modules/private" |
||||||
|
repo_module "code.gitea.io/gitea/modules/repository" |
||||||
|
"code.gitea.io/gitea/services/contexttest" |
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert" |
||||||
|
) |
||||||
|
|
||||||
|
func TestHandlePullRequestMerging(t *testing.T) { |
||||||
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
||||||
|
pr, err := issues_model.GetUnmergedPullRequest(db.DefaultContext, 1, 1, "branch2", "master", issues_model.PullRequestFlowGithub) |
||||||
|
assert.NoError(t, err) |
||||||
|
assert.NoError(t, pr.LoadBaseRepo(db.DefaultContext)) |
||||||
|
|
||||||
|
user1 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1}) |
||||||
|
|
||||||
|
err = pull_model.ScheduleAutoMerge(db.DefaultContext, user1, pr.ID, repo_model.MergeStyleSquash, "squash merge a pr") |
||||||
|
assert.NoError(t, err) |
||||||
|
|
||||||
|
autoMerge := unittest.AssertExistsAndLoadBean(t, &pull_model.AutoMerge{PullID: pr.ID}) |
||||||
|
|
||||||
|
ctx, resp := contexttest.MockPrivateContext(t, "/") |
||||||
|
handlePullRequestMerging(ctx, &private.HookOptions{ |
||||||
|
PullRequestID: pr.ID, |
||||||
|
UserID: 2, |
||||||
|
}, pr.BaseRepo.OwnerName, pr.BaseRepo.Name, []*repo_module.PushUpdateOptions{ |
||||||
|
{NewCommitID: "01234567"}, |
||||||
|
}) |
||||||
|
assert.Equal(t, 0, len(resp.Body.String())) |
||||||
|
pr, err = issues_model.GetPullRequestByID(db.DefaultContext, pr.ID) |
||||||
|
assert.NoError(t, err) |
||||||
|
assert.True(t, pr.HasMerged) |
||||||
|
assert.EqualValues(t, "01234567", pr.MergedCommitID) |
||||||
|
|
||||||
|
unittest.AssertNotExistsBean(t, &pull_model.AutoMerge{ID: autoMerge.ID}) |
||||||
|
} |
Loading…
Reference in new issue