diff --git a/checks/ci_tests.go b/checks/ci_tests.go index 09f39c79ae28..82d42bdbef51 100644 --- a/checks/ci_tests.go +++ b/checks/ci_tests.go @@ -39,17 +39,19 @@ func init() { // CITests runs CI-Tests check. func CITests(c *checker.CheckRequest) checker.CheckResult { - prs, err := c.RepoClient.ListMergedPRs() + commits, err := c.RepoClient.ListCommits() if err != nil { - e := sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListMergedPRs: %v", err)) + e := sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListCommits: %v", err)) return checker.CreateRuntimeErrorResult(CheckCITests, e) } totalMerged := 0 totalTested := 0 - for index := range prs { - pr := &prs[index] - if pr.MergedAt.IsZero() { + for i := range commits { + pr := &commits[i].AssociatedMergeRequest + // TODO(#575): We ignore associated PRs if Scorecard is being run on a fork + // but the PR was created in the original repo. + if pr.MergedAt.IsZero() || pr.Repository != c.Repo.String() { continue } totalMerged++ diff --git a/checks/code_review.go b/checks/code_review.go index 089fe7d6f2d7..c2ebe256c493 100644 --- a/checks/code_review.go +++ b/checks/code_review.go @@ -95,12 +95,15 @@ func githubCodeReview(c *checker.CheckRequest) (int, string, error) { // Look at some merged PRs to see if they were reviewed. totalMerged := 0 totalReviewed := 0 - prs, err := c.RepoClient.ListMergedPRs() + commits, err := c.RepoClient.ListCommits() if err != nil { - return 0, "", sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListMergedPRs: %v", err)) + return 0, "", sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.Commits: %v", err)) } - for _, pr := range prs { - if pr.MergedAt.IsZero() { + for _, commit := range commits { + pr := commit.AssociatedMergeRequest + // TODO(#575): We ignore associated PRs if Scorecard is being run on a fork + // but the PR was created in the original repo. + if pr.MergedAt.IsZero() || pr.Repository != c.Repo.String() { continue } totalMerged++ @@ -122,11 +125,11 @@ func githubCodeReview(c *checker.CheckRequest) (int, string, error) { // of equivalent to a review and is done several times on small prs to save // time on clicking the approve button. if !foundApprovedReview && - pr.MergeCommit.Committer.Login != "" && - pr.MergeCommit.Committer.Login != pr.Author.Login { + commit.Committer.Login != "" && + commit.Committer.Login != pr.Author.Login { c.Dlogger.Debug3(&checker.LogMessage{ Text: fmt.Sprintf("found PR#%d with committer (%s) different from author (%s)", - pr.Number, pr.Author.Login, pr.MergeCommit.Committer.Login), + pr.Number, pr.Author.Login, commit.Committer.Login), }) totalReviewed++ foundApprovedReview = true @@ -148,12 +151,15 @@ func prowCodeReview(c *checker.CheckRequest) (int, string, error) { // Look at some merged PRs to see if they were reviewed totalMerged := 0 totalReviewed := 0 - prs, err := c.RepoClient.ListMergedPRs() + commits, err := c.RepoClient.ListCommits() if err != nil { - sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListMergedPRs: %v", err)) + sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListCommits: %v", err)) } - for _, pr := range prs { - if pr.MergedAt.IsZero() { + for _, commit := range commits { + pr := commit.AssociatedMergeRequest + // TODO(#575): We ignore associated PRs if Scorecard is being run on a fork + // but the PR was created in the original repo. + if pr.MergedAt.IsZero() || pr.Repository != c.Repo.String() { continue } totalMerged++ diff --git a/checks/code_review_test.go b/checks/code_review_test.go index 9ddc251b752a..9ed5c5e667ac 100644 --- a/checks/code_review_test.go +++ b/checks/code_review_test.go @@ -30,14 +30,15 @@ import ( // TestCodeReview tests the code review checker. func TestCodereview(t *testing.T) { t.Parallel() - //fieldalignment lint issue. Ignoring it as it is not important for this test. - //nolint + const testRepo = "test-repo" + + // fieldalignment lint issue. Ignoring it as it is not important for this test. + // nolint: govet, goerr113 tests := []struct { err error name string commiterr error commits []clients.Commit - prs []clients.PullRequest expected checker.CheckResult }{ { @@ -70,132 +71,145 @@ func TestCodereview(t *testing.T) { }, { name: "Valid PR's and commits as not a bot", - prs: []clients.PullRequest{ - { - Number: 1, - MergedAt: time.Now(), - Reviews: []clients.Review{ - { - State: "APPROVED", - }, - }, - Labels: []clients.Label{ - { - Name: "lgtm", - }, - }, - }, - }, commits: []clients.Commit{ { SHA: "sha", Committer: clients.User{ Login: "user", }, + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + Number: 1, + MergedAt: time.Now(), + Reviews: []clients.Review{ + { + State: "APPROVED", + }, + }, + Labels: []clients.Label{ + { + Name: "lgtm", + }, + }, + }, }, }, - expected: checker.CheckResult{ Score: 10, Pass: true, }, }, - { name: "Valid PR's and commits as bot", - prs: []clients.PullRequest{ - { - Number: 1, - MergedAt: time.Now(), - Reviews: []clients.Review{ - { - State: "APPROVED", - }, - }, - Labels: []clients.Label{ - { - Name: "lgtm", - }, - }, - }, - }, commits: []clients.Commit{ { SHA: "sha", Committer: clients.User{ Login: "bot", }, + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + Number: 1, + MergedAt: time.Now(), + Reviews: []clients.Review{ + { + State: "APPROVED", + }, + }, + Labels: []clients.Label{ + { + Name: "lgtm", + }, + }, + }, }, }, - expected: checker.CheckResult{ Score: 10, Pass: true, }, }, - { name: "Valid PR's and commits not yet merged", - prs: []clients.PullRequest{ - { - Number: 1, - Reviews: []clients.Review{ - { - State: "APPROVED", - }, - }, - Labels: []clients.Label{ - { - Name: "lgtm", - }, - }, - }, - }, commits: []clients.Commit{ { SHA: "sha", Committer: clients.User{ Login: "bot", }, + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + Number: 1, + Reviews: []clients.Review{ + { + State: "APPROVED", + }, + }, + Labels: []clients.Label{ + { + Name: "lgtm", + }, + }, + }, }, }, - expected: checker.CheckResult{ Score: -1, }, }, { name: "Valid PR's and commits with merged by someone else", - prs: []clients.PullRequest{ + commits: []clients.Commit{ { - Number: 1, - Reviews: []clients.Review{ - { - State: "APPROVED", - }, + SHA: "sha", + Committer: clients.User{ + Login: "bot", }, - Labels: []clients.Label{ - { - Name: "lgtm", + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + Number: 1, + Reviews: []clients.Review{ + { + State: "APPROVED", + }, }, - }, - MergeCommit: clients.Commit{ - SHA: "sha", - Committer: clients.User{ - Login: "bob", + Labels: []clients.Label{ + { + Name: "lgtm", + }, }, }, }, }, + expected: checker.CheckResult{ + Score: -1, + }, + }, + { + name: "Merged PR in a different repo", commits: []clients.Commit{ { SHA: "sha", Committer: clients.User{ Login: "bot", }, + AssociatedMergeRequest: clients.PullRequest{ + Repository: "does-not-exist", + MergedAt: time.Now(), + Number: 1, + Reviews: []clients.Review{ + { + State: "APPROVED", + }, + }, + Labels: []clients.Label{ + { + Name: "lgtm", + }, + }, + }, }, }, - expected: checker.CheckResult{ Score: -1, }, @@ -207,22 +221,19 @@ func TestCodereview(t *testing.T) { t.Run(tt.name, func(t *testing.T) { t.Parallel() ctrl := gomock.NewController(t) - mockRepo := mockrepo.NewMockRepoClient(ctrl) - mockRepo.EXPECT().ListMergedPRs().DoAndReturn(func() ([]clients.PullRequest, error) { - if tt.err != nil { - return tt.prs, tt.err - } - return tt.prs, tt.err - }).AnyTimes() - mockRepo.EXPECT().ListCommits().DoAndReturn(func() ([]clients.Commit, error) { + mockRepoClient := mockrepo.NewMockRepoClient(ctrl) + mockRepoClient.EXPECT().ListCommits().DoAndReturn(func() ([]clients.Commit, error) { if tt.commiterr != nil { return tt.commits, tt.commiterr } return tt.commits, tt.err }).AnyTimes() + mockRepo := mockrepo.NewMockRepo(ctrl) + mockRepo.EXPECT().String().Return(testRepo).AnyTimes() req := checker.CheckRequest{ - RepoClient: mockRepo, + RepoClient: mockRepoClient, + Repo: mockRepo, } req.Dlogger = &scut.TestDetailLogger{} res := DoesCodeReview(&req) diff --git a/checks/maintained.go b/checks/maintained.go index b4d7089af5e4..7e33a962ad18 100644 --- a/checks/maintained.go +++ b/checks/maintained.go @@ -59,8 +59,8 @@ func IsMaintained(c *checker.CheckRequest) checker.CheckResult { return checker.CreateRuntimeErrorResult(CheckMaintained, e) } commitsWithinThreshold := 0 - for _, commit := range commits { - if commit.CommittedDate.After(threshold) { + for i := range commits { + if commits[i].CommittedDate.After(threshold) { commitsWithinThreshold++ } } diff --git a/checks/sast.go b/checks/sast.go index 30f39cc17083..301d735348e8 100644 --- a/checks/sast.go +++ b/checks/sast.go @@ -108,17 +108,20 @@ func SAST(c *checker.CheckRequest) checker.CheckResult { // nolint func sastToolInCheckRuns(c *checker.CheckRequest) (int, error) { - prs, err := c.RepoClient.ListMergedPRs() + commits, err := c.RepoClient.ListCommits() if err != nil { //nolint return checker.InconclusiveResultScore, - sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListMergedPRs: %v", err)) + sce.WithMessage(sce.ErrScorecardInternal, fmt.Sprintf("RepoClient.ListCommits: %v", err)) } totalMerged := 0 totalTested := 0 - for _, pr := range prs { - if pr.MergedAt.IsZero() { + for _, commit := range commits { + pr := commit.AssociatedMergeRequest + // TODO(#575): We ignore associated PRs if Scorecard is being run on a fork + // but the PR was created in the original repo. + if pr.MergedAt.IsZero() || pr.Repository != c.Repo.String() { continue } totalMerged++ diff --git a/checks/sast_test.go b/checks/sast_test.go index d29b873b93c7..06af92bdc0fb 100644 --- a/checks/sast_test.go +++ b/checks/sast_test.go @@ -30,10 +30,12 @@ import ( func TestSAST(t *testing.T) { t.Parallel() - //nolint + + const testRepo = "test-repo" + // nolint: govet, goerr113 tests := []struct { name string - prs []clients.PullRequest + commits []clients.Commit err error searchresult clients.SearchResponse checkRuns []clients.CheckRun @@ -42,23 +44,26 @@ func TestSAST(t *testing.T) { }{ { name: "SAST checker should return failed status when no PRs are found", - prs: []clients.PullRequest{}, + commits: []clients.Commit{}, searchresult: clients.SearchResponse{}, checkRuns: []clients.CheckRun{}, }, { name: "SAST checker should return failed status when no PRs are found", err: errors.New("error"), - prs: []clients.PullRequest{}, + commits: []clients.Commit{}, searchresult: clients.SearchResponse{}, checkRuns: []clients.CheckRun{}, expected: checker.CheckResult{Score: -1, Pass: false}, }, { name: "Successful SAST checker should return success status", - prs: []clients.PullRequest{ + commits: []clients.Commit{ { - MergedAt: time.Now().Add(time.Hour - 1), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 1), + }, }, }, searchresult: clients.SearchResponse{}, @@ -78,18 +83,30 @@ func TestSAST(t *testing.T) { }, { name: "Failed SAST checker should return success status", - prs: []clients.PullRequest{ + commits: []clients.Commit{ { - MergedAt: time.Now().Add(time.Hour - 1), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 1), + }, }, { - MergedAt: time.Now().Add(time.Hour - 10), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 10), + }, }, { - MergedAt: time.Now().Add(time.Hour - 20), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 20), + }, }, { - MergedAt: time.Now().Add(time.Hour - 30), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 30), + }, }, }, searchresult: clients.SearchResponse{Hits: 1, Results: []clients.SearchResult{{ @@ -110,18 +127,30 @@ func TestSAST(t *testing.T) { }, { name: "Failed SAST checker with checkRuns not completed", - prs: []clients.PullRequest{ + commits: []clients.Commit{ { - MergedAt: time.Now().Add(time.Hour - 1), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 1), + }, }, { - MergedAt: time.Now().Add(time.Hour - 10), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 10), + }, }, { - MergedAt: time.Now().Add(time.Hour - 20), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 20), + }, }, { - MergedAt: time.Now().Add(time.Hour - 30), + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + MergedAt: time.Now().Add(time.Hour - 30), + }, }, }, searchresult: clients.SearchResponse{}, @@ -139,9 +168,36 @@ func TestSAST(t *testing.T) { }, { name: "Failed SAST with PullRequest not merged", - prs: []clients.PullRequest{ + commits: []clients.Commit{ { - Number: 1, + AssociatedMergeRequest: clients.PullRequest{ + Repository: testRepo, + Number: 1, + }, + }, + }, + searchresult: clients.SearchResponse{}, + checkRuns: []clients.CheckRun{ + { + App: clients.CheckRunApp{ + Slug: "lgtm-com", + }, + }, + }, + expected: checker.CheckResult{ + Score: 0, + Pass: false, + }, + }, + { + name: "Merged PullRequest in a different repo", + commits: []clients.Commit{ + { + AssociatedMergeRequest: clients.PullRequest{ + Repository: "does-not-exist", + MergedAt: time.Now(), + Number: 1, + }, }, }, searchresult: clients.SearchResponse{}, @@ -167,20 +223,23 @@ func TestSAST(t *testing.T) { t.Run(tt.name, func(t *testing.T) { t.Parallel() ctrl := gomock.NewController(t) - mockRepo := mockrepo.NewMockRepoClient(ctrl) - - mockRepo.EXPECT().ListMergedPRs().DoAndReturn(func() ([]clients.PullRequest, error) { + mockRepoClient := mockrepo.NewMockRepoClient(ctrl) + mockRepoClient.EXPECT().ListCommits().DoAndReturn(func() ([]clients.Commit, error) { if tt.err != nil { return nil, tt.err } - return tt.prs, tt.err + return tt.commits, tt.err }) - mockRepo.EXPECT().ListCheckRunsForRef("").Return(tt.checkRuns, nil).AnyTimes() - mockRepo.EXPECT().Search(searchRequest).Return(tt.searchresult, nil).AnyTimes() + mockRepoClient.EXPECT().ListCheckRunsForRef("").Return(tt.checkRuns, nil).AnyTimes() + mockRepoClient.EXPECT().Search(searchRequest).Return(tt.searchresult, nil).AnyTimes() + + mockRepo := mockrepo.NewMockRepo(ctrl) + mockRepo.EXPECT().String().Return(testRepo).AnyTimes() dl := scut.TestDetailLogger{} req := checker.CheckRequest{ - RepoClient: mockRepo, + RepoClient: mockRepoClient, + Repo: mockRepo, Ctx: context.TODO(), Dlogger: &dl, } diff --git a/clients/commit.go b/clients/commit.go index fb8105cd0d3d..3ff5cc13994a 100644 --- a/clients/commit.go +++ b/clients/commit.go @@ -18,8 +18,9 @@ import "time" // Commit represents a Git commit. type Commit struct { - CommittedDate time.Time - Message string - SHA string - Committer User + CommittedDate time.Time + Message string + SHA string + Committer User + AssociatedMergeRequest PullRequest } diff --git a/clients/githubrepo/client.go b/clients/githubrepo/client.go index e21f3ca85f83..49a1b89ea5f1 100644 --- a/clients/githubrepo/client.go +++ b/clients/githubrepo/client.go @@ -113,11 +113,6 @@ func (client *Client) GetFileContent(filename string) ([]byte, error) { return client.tarball.getFileContent(filename) } -// ListMergedPRs implements RepoClient.ListMergedPRs. -func (client *Client) ListMergedPRs() ([]clients.PullRequest, error) { - return client.graphClient.getMergedPRs() -} - // ListCommits implements RepoClient.ListCommits. func (client *Client) ListCommits() ([]clients.Commit, error) { return client.graphClient.getCommits() diff --git a/clients/githubrepo/graphql.go b/clients/githubrepo/graphql.go index 3d312a4383dd..3888acceddf5 100644 --- a/clients/githubrepo/graphql.go +++ b/clients/githubrepo/graphql.go @@ -121,7 +121,6 @@ type graphqlHandler struct { errSetup error owner string repo string - prs []clients.PullRequest commits []clients.Commit issues []clients.Issue archived bool @@ -153,7 +152,6 @@ func (handler *graphqlHandler) setup() error { return } handler.archived = bool(handler.data.Repository.IsArchived) - handler.prs = pullRequestsFrom(handler.data, handler.owner, handler.repo) handler.commits, handler.errSetup = commitsFrom(handler.data) if handler.errSetup != nil { return @@ -163,13 +161,6 @@ func (handler *graphqlHandler) setup() error { return handler.errSetup } -func (handler *graphqlHandler) getMergedPRs() ([]clients.PullRequest, error) { - if err := handler.setup(); err != nil { - return nil, fmt.Errorf("error during graphqlHandler.setup: %w", err) - } - return handler.prs, nil -} - func (handler *graphqlHandler) getCommits() ([]clients.Commit, error) { if err := handler.setup(); err != nil { return nil, fmt.Errorf("error during graphqlHandler.setup: %w", err) @@ -191,61 +182,54 @@ func (handler *graphqlHandler) isArchived() (bool, error) { return handler.archived, nil } -func pullRequestsFrom(data *graphqlData, repoOwner, repoName string) []clients.PullRequest { - var ret []clients.PullRequest +func commitsFrom(data *graphqlData) ([]clients.Commit, error) { + ret := make([]clients.Commit, 0) for _, commit := range data.Repository.DefaultBranchRef.Target.Commit.History.Nodes { + var committer string + if commit.Committer.User.Login != nil { + committer = *commit.Committer.User.Login + } else if commit.Committer.Name != nil { + committer = *commit.Committer.Name + // committer.name will be set to `github` if this was auto-merged by GitHub. + if !strings.EqualFold(committer, allowedCommitterName) { + return nil, sce.WithMessage(sce.ErrScorecardInternal, + fmt.Sprintf("committer name is not '%s': %s", allowedCommitterName, committer)) + } + } + var associatedPR clients.PullRequest for i := range commit.AssociatedPullRequests.Nodes { pr := commit.AssociatedPullRequests.Nodes[i] - if pr.MergeCommit.Oid != commit.Oid || - string(pr.Repository.Name) != repoName || - string(pr.Repository.Owner.Login) != repoOwner { + if pr.MergeCommit.Oid != commit.Oid { continue } - toAppend := clients.PullRequest{ - Number: int(pr.Number), - HeadSHA: string(pr.HeadRefOid), - MergedAt: pr.MergedAt.Time, + associatedRepo, err := MakeGithubRepo(fmt.Sprintf("%s/%s", + string(pr.Repository.Owner.Login), string(pr.Repository.Name))) + if err != nil { + return nil, sce.WithMessage(sce.ErrScorecardInternal, + fmt.Sprintf("associatedPR repository is invalid %s/%s", + string(pr.Repository.Owner.Login), string(pr.Repository.Name))) + } + associatedPR = clients.PullRequest{ + Repository: associatedRepo.String(), + Number: int(pr.Number), + HeadSHA: string(pr.HeadRefOid), + MergedAt: pr.MergedAt.Time, Author: clients.User{ Login: string(pr.Author.Login), }, - // TODO(#575): Use the original commit data here directly. - MergeCommit: clients.Commit{ - Committer: clients.User{ - Login: string(commit.Author.User.Login), - }, - }, } for _, label := range pr.Labels.Nodes { - toAppend.Labels = append(toAppend.Labels, clients.Label{ + associatedPR.Labels = append(associatedPR.Labels, clients.Label{ Name: string(label.Name), }) } for _, review := range pr.Reviews.Nodes { - toAppend.Reviews = append(toAppend.Reviews, clients.Review{ + associatedPR.Reviews = append(associatedPR.Reviews, clients.Review{ State: string(review.State), }) } - ret = append(ret, toAppend) break } - } - return ret -} - -func commitsFrom(data *graphqlData) ([]clients.Commit, error) { - ret := make([]clients.Commit, 0) - for _, commit := range data.Repository.DefaultBranchRef.Target.Commit.History.Nodes { - var committer string - if commit.Committer.User.Login != nil { - committer = *commit.Committer.User.Login - } else if commit.Committer.Name != nil { - committer = *commit.Committer.Name - // committer.name will be set to `github` if this was auto-merged by GitHub. - if !strings.EqualFold(committer, allowedCommitterName) { - return nil, sce.WithMessage(sce.ErrScorecardInternal, - fmt.Sprintf("committer name is not '%s': %s", allowedCommitterName, committer)) - } - } ret = append(ret, clients.Commit{ CommittedDate: commit.CommittedDate.Time, Message: string(commit.Message), @@ -253,6 +237,7 @@ func commitsFrom(data *graphqlData) ([]clients.Commit, error) { Committer: clients.User{ Login: committer, }, + AssociatedMergeRequest: associatedPR, }) } return ret, nil diff --git a/clients/localdir/client.go b/clients/localdir/client.go index 27e5c0f30e86..6f0e76d44f09 100644 --- a/clients/localdir/client.go +++ b/clients/localdir/client.go @@ -153,11 +153,6 @@ func (client *localDirClient) GetFileContent(filename string) ([]byte, error) { return getFileContent(client.path, filename) } -// ListMergedPRs implements RepoClient.ListMergedPRs. -func (client *localDirClient) ListMergedPRs() ([]clients.PullRequest, error) { - return nil, fmt.Errorf("ListMergedPRs: %w", clients.ErrUnsupportedFeature) -} - // ListBranches implements RepoClient.ListBranches. func (client *localDirClient) ListBranches() ([]*clients.BranchRef, error) { return nil, fmt.Errorf("ListBranches: %w", clients.ErrUnsupportedFeature) diff --git a/clients/mockclients/repo_client.go b/clients/mockclients/repo_client.go index c1ff27ff3f8b..f6a70371ffed 100644 --- a/clients/mockclients/repo_client.go +++ b/clients/mockclients/repo_client.go @@ -212,21 +212,6 @@ func (mr *MockRepoClientMockRecorder) ListIssues() *gomock.Call { return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "ListIssues", reflect.TypeOf((*MockRepoClient)(nil).ListIssues)) } -// ListMergedPRs mocks base method. -func (m *MockRepoClient) ListMergedPRs() ([]clients.PullRequest, error) { - m.ctrl.T.Helper() - ret := m.ctrl.Call(m, "ListMergedPRs") - ret0, _ := ret[0].([]clients.PullRequest) - ret1, _ := ret[1].(error) - return ret0, ret1 -} - -// ListMergedPRs indicates an expected call of ListMergedPRs. -func (mr *MockRepoClientMockRecorder) ListMergedPRs() *gomock.Call { - mr.mock.ctrl.T.Helper() - return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "ListMergedPRs", reflect.TypeOf((*MockRepoClient)(nil).ListMergedPRs)) -} - // ListReleases mocks base method. func (m *MockRepoClient) ListReleases() ([]clients.Release, error) { m.ctrl.T.Helper() diff --git a/clients/pull_request.go b/clients/pull_request.go index a7ef3141c089..d4abaf9525d4 100644 --- a/clients/pull_request.go +++ b/clients/pull_request.go @@ -21,13 +21,13 @@ import ( // PullRequest struct represents a PR as returned by RepoClient. // nolint: govet type PullRequest struct { - MergedAt time.Time - MergeCommit Commit - Number int - HeadSHA string - Labels []Label - Reviews []Review - Author User + Number int + MergedAt time.Time + HeadSHA string + Repository string + Author User + Labels []Label + Reviews []Review } // Label represents a PR label. diff --git a/clients/repo_client.go b/clients/repo_client.go index 97dc59b07e5d..5f78f46b017e 100644 --- a/clients/repo_client.go +++ b/clients/repo_client.go @@ -27,7 +27,6 @@ type RepoClient interface { IsArchived() (bool, error) ListFiles(predicate func(string) (bool, error)) ([]string, error) GetFileContent(filename string) ([]byte, error) - ListMergedPRs() ([]PullRequest, error) ListBranches() ([]*BranchRef, error) GetDefaultBranch() (*BranchRef, error) ListCommits() ([]Commit, error) diff --git a/docs/checks/internal/validate/main.go b/docs/checks/internal/validate/main.go index 734c23943d47..2fd38d335944 100644 --- a/docs/checks/internal/validate/main.go +++ b/docs/checks/internal/validate/main.go @@ -40,7 +40,6 @@ var ( "IsArchived": {"GitHub"}, "ListFiles": {"GitHub", "local"}, "GetFileContent": {"GitHub", "local"}, - "ListMergedPRs": {"GitHub"}, "ListBranches": {"GitHub"}, "GetDefaultBranch": {"GitHub"}, "ListCommits": {"GitHub"}, @@ -67,7 +66,8 @@ func listCheckFiles() (map[string]string, error) { } for _, file := range files { - if !strings.HasSuffix(file.Name(), ".go") || file.IsDir() { + if !strings.HasSuffix(file.Name(), ".go") || + strings.HasSuffix(file.Name(), "_test.go") || file.IsDir() { continue }