mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 12:26:40 +08:00 
			
		
		
		
	Only check for conflicts/merging if the PR has not been merged in the interim (#10132)
* Only check for merging if the PR has not been merged in the interim * fixup! Only check for merging if the PR has not been merged in the interim * Try to fix test failure * Use PR2 not PR1 in tests as PR1 merges automatically * return already merged error * enforce locking * enforce locking - fix-test * enforce locking - fix-testx2 * enforce locking - fix-testx3 * move pullrequest checking to after merge This might improve the chance that the race does not affect us but does not prevent it. * Remove minor race with getting merge commit id * fixup * move check pr after merge * Remove unnecessary prepareTestEnv - onGiteaRun does this for us * Add information about when merging occuring * fix fmt * More logging * Attempt to fix mysql * Try MySQL fix again * try again * Try again?! * Try again?! * Sigh * remove the count - perhaps that will help * next remove the update id * next remove the update id - make it updated_unix instead * On failure to merge ensure that the pr is rechecked for conflict errors * On failure to merge ensure that the pr is rechecked for conflict errors * Update models/pull.go * Update models/pull.go Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * Apply suggestions from code review Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv> Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com>
This commit is contained in:
		| @ -32,7 +32,7 @@ func AddToTaskQueue(pr *models.PullRequest) { | ||||
| 	go func() { | ||||
| 		err := prQueue.PushFunc(strconv.FormatInt(pr.ID, 10), func() error { | ||||
| 			pr.Status = models.PullRequestStatusChecking | ||||
| 			err := pr.UpdateCols("status") | ||||
| 			err := pr.UpdateColsIfNotMerged("status") | ||||
| 			if err != nil { | ||||
| 				log.Error("AddToTaskQueue.UpdateCols[%d].(add to queue): %v", pr.ID, err) | ||||
| 			} else { | ||||
| @ -158,9 +158,11 @@ func manuallyMerged(pr *models.PullRequest) bool { | ||||
| 		pr.Merger = merger | ||||
| 		pr.MergerID = merger.ID | ||||
|  | ||||
| 		if err = pr.SetMerged(); err != nil { | ||||
| 		if merged, err := pr.SetMerged(); err != nil { | ||||
| 			log.Error("PullRequest[%d].setMerged : %v", pr.ID, err) | ||||
| 			return false | ||||
| 		} else if !merged { | ||||
| 			return false | ||||
| 		} | ||||
|  | ||||
| 		notification.NotifyMergePullRequest(pr, merger) | ||||
| @ -205,7 +207,7 @@ func handle(data ...queue.Data) { | ||||
| 		if err != nil { | ||||
| 			log.Error("GetPullRequestByID[%s]: %v", prID, err) | ||||
| 			continue | ||||
| 		} else if pr.Status != models.PullRequestStatusChecking { | ||||
| 		} else if pr.HasMerged { | ||||
| 			continue | ||||
| 		} else if manuallyMerged(pr) { | ||||
| 			continue | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 zeripath
					zeripath