Fix regression in PR-API #248 (#349)

* Fix #344 (regression in PR-API #248)
pull/348/head
Kim "BKC" Carlbäcker 2016-12-05 12:17:39 +01:00 committed by GitHub
parent edae0f134c
commit d07c955e2a
1 changed files with 39 additions and 7 deletions

View File

@ -121,12 +121,40 @@ func (pr *PullRequest) LoadIssue() (err error) {
// Required - Issue // Required - Issue
// Optional - Merger // Optional - Merger
func (pr *PullRequest) APIFormat() *api.PullRequest { func (pr *PullRequest) APIFormat() *api.PullRequest {
var (
baseBranch *Branch
headBranch *Branch
baseCommit *git.Commit
headCommit *git.Commit
err error
)
apiIssue := pr.Issue.APIFormat() apiIssue := pr.Issue.APIFormat()
baseBranch, _ := pr.BaseRepo.GetBranch(pr.BaseBranch) if pr.BaseRepo == nil {
baseCommit, _ := baseBranch.GetCommit() pr.BaseRepo, err = GetRepositoryByID(pr.BaseRepoID)
headBranch, _ := pr.HeadRepo.GetBranch(pr.HeadBranch) if err != nil {
headCommit, _ := headBranch.GetCommit() log.Error(log.ERROR, "GetRepositoryById[%d]: %v", pr.ID, err)
return nil
}
}
if pr.HeadRepo == nil {
pr.HeadRepo, err = GetRepositoryByID(pr.HeadRepoID)
if err != nil {
log.Error(log.ERROR, "GetRepositoryById[%d]: %v", pr.ID, err)
return nil
}
}
if baseBranch, err = pr.BaseRepo.GetBranch(pr.BaseBranch); err != nil {
return nil
}
if baseCommit, err = baseBranch.GetCommit(); err != nil {
return nil
}
if headBranch, err = pr.HeadRepo.GetBranch(pr.HeadBranch); err != nil {
return nil
}
if headCommit, err = headBranch.GetCommit(); err != nil {
return nil
}
apiBaseBranchInfo := &api.PRBranchInfo{ apiBaseBranchInfo := &api.PRBranchInfo{
Name: pr.BaseBranch, Name: pr.BaseBranch,
Ref: pr.BaseBranch, Ref: pr.BaseBranch,
@ -590,8 +618,12 @@ func GetPullRequestByIndex(repoID int64, index int64) (*PullRequest, error) {
return nil, ErrPullRequestNotExist{0, repoID, index, 0, "", ""} return nil, ErrPullRequestNotExist{0, repoID, index, 0, "", ""}
} }
pr.LoadAttributes() if err = pr.LoadAttributes(); err != nil {
pr.LoadIssue() return nil, err
}
if err = pr.LoadIssue(); err != nil {
return nil, err
}
return pr, nil return pr, nil
} }