mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 03:52:24 +00:00 
			
		
		
		
	Make manual merge autodetection optional and add manual merge as merge method (#12543)
* Make auto check manual merge as a chooseable mod and add manual merge way on ui as title, Before this pr, we use same way with GH to check manually merge. It good, but in some special cases, misjudgments can occur. and it's hard to fix this bug. So I add option to allow repo manager block "auto check manual merge" function, Then it will have same style like gitlab(allow empty pr). and to compensate for not being able to detect THE PR merge automatically, I added a manual approach. Signed-off-by: a1012112796 <1012112796@qq.com> * make swager * api support * ping ci * fix TestPullCreate_EmptyChangesWithCommits * Apply suggestions from code review Co-authored-by: zeripath <art27@cantab.net> * Apply review suggestions and add test * Apply suggestions from code review Co-authored-by: zeripath <art27@cantab.net> * fix build * test error message * make fmt * Fix indentation issues identified by @silverwind Co-authored-by: silverwind <me@silverwind.io> * Fix tests and make manually merged disabled error on API the same Signed-off-by: Andrew Thornton <art27@cantab.net> * a small nit * fix wrong commit id error * fix bug * simple test * fix test Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
This commit is contained in:
		
					parent
					
						
							
								523efa433b
							
						
					
				
			
			
				commit
				
					
						a5279b74b6
					
				
			
		
					 25 changed files with 379 additions and 23 deletions
				
			
		|  | @ -116,7 +116,7 @@ func getMergeCommit(pr *models.PullRequest) (*git.Commit, error) { | |||
| 	if err != nil { | ||||
| 		return nil, fmt.Errorf("git rev-list --ancestry-path --merges --reverse: %v", err) | ||||
| 	} else if len(mergeCommit) < 40 { | ||||
| 		// PR was fast-forwarded, so just use last commit of PR | ||||
| 		// PR was maybe fast-forwarded, so just use last commit of PR | ||||
| 		mergeCommit = commitID[:40] | ||||
| 	} | ||||
| 
 | ||||
|  | @ -137,6 +137,21 @@ func getMergeCommit(pr *models.PullRequest) (*git.Commit, error) { | |||
| // manuallyMerged checks if a pull request got manually merged | ||||
| // When a pull request got manually merged mark the pull request as merged | ||||
| func manuallyMerged(pr *models.PullRequest) bool { | ||||
| 	if err := pr.LoadBaseRepo(); err != nil { | ||||
| 		log.Error("PullRequest[%d].LoadBaseRepo: %v", pr.ID, err) | ||||
| 		return false | ||||
| 	} | ||||
| 
 | ||||
| 	if unit, err := pr.BaseRepo.GetUnit(models.UnitTypePullRequests); err == nil { | ||||
| 		config := unit.PullRequestsConfig() | ||||
| 		if !config.AutodetectManualMerge { | ||||
| 			return false | ||||
| 		} | ||||
| 	} else { | ||||
| 		log.Error("PullRequest[%d].BaseRepo.GetUnit(models.UnitTypePullRequests): %v", pr.ID, err) | ||||
| 		return false | ||||
| 	} | ||||
| 
 | ||||
| 	commit, err := getMergeCommit(pr) | ||||
| 	if err != nil { | ||||
| 		log.Error("PullRequest[%d].getMergeCommit: %v", pr.ID, err) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue