mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 12:27:06 +00:00 
			
		
		
		
	Fix pull request check list is limited (#26179)
In the original implementation, we can only get the first 30 records of the commit status (the default paging size), if the commit status is more than 30, it will lead to the bug #25990. I made the following two changes. - On the page, use the ` db.ListOptions{ListAll: true}` parameter instead of `db.ListOptions{}` - The `GetLatestCommitStatus` function makes a determination as to whether or not a pager is being used. fixed #25990
This commit is contained in:
		| @@ -283,9 +283,9 @@ func GetLatestCommitStatus(ctx context.Context, repoID int64, sha string, listOp | ||||
| 		Where("repo_id = ?", repoID).And("sha = ?", sha). | ||||
| 		Select("max( id ) as id"). | ||||
| 		GroupBy("context_hash").OrderBy("max( id ) desc") | ||||
|  | ||||
| 	if !listOptions.IsListAll() { | ||||
| 		sess = db.SetSessionPagination(sess, &listOptions) | ||||
|  | ||||
| 	} | ||||
| 	count, err := sess.FindAndCount(&ids) | ||||
| 	if err != nil { | ||||
| 		return nil, count, err | ||||
|   | ||||
| @@ -349,7 +349,7 @@ func Diff(ctx *context.Context) { | ||||
| 	ctx.Data["Commit"] = commit | ||||
| 	ctx.Data["Diff"] = diff | ||||
|  | ||||
| 	statuses, _, err := git_model.GetLatestCommitStatus(ctx, ctx.Repo.Repository.ID, commitID, db.ListOptions{}) | ||||
| 	statuses, _, err := git_model.GetLatestCommitStatus(ctx, ctx.Repo.Repository.ID, commitID, db.ListOptions{ListAll: true}) | ||||
| 	if err != nil { | ||||
| 		log.Error("GetLatestCommitStatus: %v", err) | ||||
| 	} | ||||
|   | ||||
| @@ -469,7 +469,7 @@ func PrepareMergedViewPullInfo(ctx *context.Context, issue *issues_model.Issue) | ||||
|  | ||||
| 	if len(compareInfo.Commits) != 0 { | ||||
| 		sha := compareInfo.Commits[0].ID.String() | ||||
| 		commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, ctx.Repo.Repository.ID, sha, db.ListOptions{}) | ||||
| 		commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, ctx.Repo.Repository.ID, sha, db.ListOptions{ListAll: true}) | ||||
| 		if err != nil { | ||||
| 			ctx.ServerError("GetLatestCommitStatus", err) | ||||
| 			return nil | ||||
| @@ -531,7 +531,7 @@ func PrepareViewPullInfo(ctx *context.Context, issue *issues_model.Issue) *git.C | ||||
| 			ctx.ServerError(fmt.Sprintf("GetRefCommitID(%s)", pull.GetGitRefName()), err) | ||||
| 			return nil | ||||
| 		} | ||||
| 		commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, repo.ID, sha, db.ListOptions{}) | ||||
| 		commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, repo.ID, sha, db.ListOptions{ListAll: true}) | ||||
| 		if err != nil { | ||||
| 			ctx.ServerError("GetLatestCommitStatus", err) | ||||
| 			return nil | ||||
| @@ -623,7 +623,7 @@ func PrepareViewPullInfo(ctx *context.Context, issue *issues_model.Issue) *git.C | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, repo.ID, sha, db.ListOptions{}) | ||||
| 	commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, repo.ID, sha, db.ListOptions{ListAll: true}) | ||||
| 	if err != nil { | ||||
| 		ctx.ServerError("GetLatestCommitStatus", err) | ||||
| 		return nil | ||||
|   | ||||
| @@ -842,7 +842,7 @@ func renderDirectoryFiles(ctx *context.Context, timeout time.Duration) git.Entri | ||||
| 		ctx.Data["LatestCommitVerification"] = verification | ||||
| 		ctx.Data["LatestCommitUser"] = user_model.ValidateCommitWithEmail(ctx, latestCommit) | ||||
|  | ||||
| 		statuses, _, err := git_model.GetLatestCommitStatus(ctx, ctx.Repo.Repository.ID, latestCommit.ID.String(), db.ListOptions{}) | ||||
| 		statuses, _, err := git_model.GetLatestCommitStatus(ctx, ctx.Repo.Repository.ID, latestCommit.ID.String(), db.ListOptions{ListAll: true}) | ||||
| 		if err != nil { | ||||
| 			log.Error("GetLatestCommitStatus: %v", err) | ||||
| 		} | ||||
|   | ||||
| @@ -75,7 +75,7 @@ func createCommitStatus(ctx context.Context, job *actions_model.ActionRunJob) er | ||||
| 	} | ||||
| 	ctxname := fmt.Sprintf("%s / %s (%s)", runName, job.Name, event) | ||||
| 	state := toCommitStatus(job.Status) | ||||
| 	if statuses, _, err := git_model.GetLatestCommitStatus(ctx, repo.ID, sha, db.ListOptions{}); err == nil { | ||||
| 	if statuses, _, err := git_model.GetLatestCommitStatus(ctx, repo.ID, sha, db.ListOptions{ListAll: true}); err == nil { | ||||
| 		for _, v := range statuses { | ||||
| 			if v.Context == ctxname { | ||||
| 				if v.State == state { | ||||
|   | ||||
| @@ -143,7 +143,7 @@ func GetPullRequestCommitStatusState(ctx context.Context, pr *issues_model.PullR | ||||
| 		return "", errors.Wrap(err, "LoadBaseRepo") | ||||
| 	} | ||||
|  | ||||
| 	commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, pr.BaseRepo.ID, sha, db.ListOptions{}) | ||||
| 	commitStatuses, _, err := git_model.GetLatestCommitStatus(ctx, pr.BaseRepo.ID, sha, db.ListOptions{ListAll: true}) | ||||
| 	if err != nil { | ||||
| 		return "", errors.Wrap(err, "GetLatestCommitStatus") | ||||
| 	} | ||||
|   | ||||
| @@ -804,7 +804,7 @@ func getAllCommitStatus(gitRepo *git.Repository, pr *issues_model.PullRequest) ( | ||||
| 		return nil, nil, shaErr | ||||
| 	} | ||||
|  | ||||
| 	statuses, _, err = git_model.GetLatestCommitStatus(db.DefaultContext, pr.BaseRepo.ID, sha, db.ListOptions{}) | ||||
| 	statuses, _, err = git_model.GetLatestCommitStatus(db.DefaultContext, pr.BaseRepo.ID, sha, db.ListOptions{ListAll: true}) | ||||
| 	lastStatus = git_model.CalcCommitStatus(statuses) | ||||
| 	return statuses, lastStatus, err | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 caicandong
					caicandong