gitea/modules/repository
Giteabot ec3f5f9992
Move database operations of merging a pull request to post receive hook and add a transaction (#30805) (#30888)
Backport #30805 by @lunny

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: Lunny Xiao <xiaolunwen@gmail.com>
Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
2024-05-08 14:17:18 +00:00
..
branch.go Make "sync branch" also sync object format and add tests (#30878) (#30880) 2024-05-07 08:33:28 +08:00
branch_test.go Make "sync branch" also sync object format and add tests (#30878) (#30880) 2024-05-07 08:33:28 +08:00
collaborator.go Add user blocking (#29028) 2024-03-04 08:16:03 +00:00
collaborator_test.go
commits.go
commits_test.go
create.go Add user blocking (#29028) 2024-03-04 08:16:03 +00:00
create_test.go
delete.go
env.go Move database operations of merging a pull request to post receive hook and add a transaction (#30805) (#30888) 2024-05-08 14:17:18 +00:00
fork.go
hooks.go
init.go
init_test.go
license.go
license_test.go
main_test.go
push.go
repo.go
repo_test.go
temp.go Enable more `revive` linter rules (#30608) 2024-04-22 11:48:42 +00:00