From fd89b794ef67997a27b1eed17f3525f288a10eaa Mon Sep 17 00:00:00 2001 From: Charles Treatman Date: Thu, 21 May 2020 13:54:27 -0400 Subject: [PATCH 1/2] Close #26: Return all open PRs instead of filtering by date This resource can inadvertently miss Pull Requests due to out-of-order commits across PRs. If PR#2 is opened after PR#1, but the head commit of PR#2 is older than the head commit of PR#1, the resource will not include PR#2 in the list of new versions provided to Concourse. Rather than attempt to find a different way of tracking which PRs are "new" given an input version, we can remove the date-based filtering and return all open PRs. Concourse can deduplicate versions based on metadata, which means that we will only trigger new jobs for versions that Concourse hasn't seen before. This makes it easier for teams to use this resource to track PRs in Concourse, since they no longer have to ensure that a PR has a later head commit than all currently-opened PRs in order to notify Concourse that their PR exists. (cherry picked from commit 50ef79a9edc28d87d9d5ed9a8a0ae40086c1389a) --- check.go | 5 ----- check_test.go | 24 +++++++++++++++++++++++- e2e/e2e_test.go | 19 ++++++------------- 3 files changed, 29 insertions(+), 19 deletions(-) diff --git a/check.go b/check.go index 4df41d04..112779bd 100644 --- a/check.go +++ b/check.go @@ -69,11 +69,6 @@ Loop: } } - // Filter out commits that are too old. - if !versionTime.After(request.Version.CommittedDate) { - continue - } - // Filter out pull request if it does not contain at least one of the desired labels if len(request.Source.Labels) > 0 { labelFound := false diff --git a/check_test.go b/check_test.go index 86b7b540..a795348d 100644 --- a/check_test.go +++ b/check_test.go @@ -64,7 +64,7 @@ func TestCheck(t *testing.T) { }, { - description: "check returns the previous version when its still latest", + description: "check returns all open PRs if there is a previous", source: resource.Source{ Repository: "itsdalmo/test-repository", AccessToken: "oauthtoken", @@ -73,7 +73,15 @@ func TestCheck(t *testing.T) { pullRequests: testPullRequests, files: [][]string{}, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[4], testPullRequests[4].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), + }, }, @@ -107,6 +115,7 @@ func TestCheck(t *testing.T) { {"terraform/modules/variables.tf", "travis.yml"}, }, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), }, }, @@ -126,6 +135,7 @@ func TestCheck(t *testing.T) { {"terraform/modules/variables.tf", "travis.yml"}, }, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), }, }, @@ -140,6 +150,14 @@ func TestCheck(t *testing.T) { version: resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), pullRequests: testPullRequests, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[4], testPullRequests[4].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[0], testPullRequests[0].Tip.CommittedDate.Time), }, }, @@ -183,6 +201,10 @@ func TestCheck(t *testing.T) { version: resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), pullRequests: testPullRequests, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), diff --git a/e2e/e2e_test.go b/e2e/e2e_test.go index 660410a2..51701798 100644 --- a/e2e/e2e_test.go +++ b/e2e/e2e_test.go @@ -24,6 +24,9 @@ import ( ) var ( + firstCommitID = "23dc9f552bf989d1a4aeb65ce23351dee0ec9019" + firstPullRequestID = "3" + firstDateTime = time.Date(2018, time.May, 11, 7, 28, 56, 0, time.UTC) targetCommitID = "a5114f6ab89f4b736655642a11e8d15ce363d882" targetPullRequestID = "4" targetDateTime = time.Date(2018, time.May, 11, 8, 43, 48, 0, time.UTC) @@ -55,25 +58,15 @@ func TestCheckE2E(t *testing.T) { }, { - description: "check returns the previous version when its still latest", + description: "check returns all open PRs if there is a previous version", source: resource.Source{ Repository: "itsdalmo/test-repository", AccessToken: os.Getenv("GITHUB_ACCESS_TOKEN"), }, version: resource.Version{PR: latestPullRequestID, Commit: latestCommitID, CommittedDate: latestDateTime}, expected: resource.CheckResponse{ - resource.Version{PR: latestPullRequestID, Commit: latestCommitID, CommittedDate: latestDateTime}, - }, - }, - - { - description: "check returns all new versions since the last", - source: resource.Source{ - Repository: "itsdalmo/test-repository", - AccessToken: os.Getenv("GITHUB_ACCESS_TOKEN"), - }, - version: resource.Version{PR: targetPullRequestID, Commit: targetCommitID, CommittedDate: targetDateTime}, - expected: resource.CheckResponse{ + resource.Version{PR: firstPullRequestID, Commit: firstCommitID, CommittedDate: firstDateTime}, + resource.Version{PR: targetPullRequestID, Commit: targetCommitID, CommittedDate: targetDateTime}, resource.Version{PR: latestPullRequestID, Commit: latestCommitID, CommittedDate: latestDateTime}, }, }, From e7c80e82a0ae57f19a416231d95051f5ab677c57 Mon Sep 17 00:00:00 2001 From: Brian Malehorn Date: Mon, 6 Dec 2021 16:54:55 -0800 Subject: [PATCH 2/2] fix up cherry-pick to pass tests --- check_test.go | 43 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 42 insertions(+), 1 deletion(-) diff --git a/check_test.go b/check_test.go index a795348d..5761ebf9 100644 --- a/check_test.go +++ b/check_test.go @@ -73,6 +73,10 @@ func TestCheck(t *testing.T) { pullRequests: testPullRequests, files: [][]string{}, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[14], testPullRequests[14].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[13], testPullRequests[13].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[12], testPullRequests[12].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[11], testPullRequests[11].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), @@ -81,7 +85,6 @@ func TestCheck(t *testing.T) { resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), - }, }, @@ -95,6 +98,16 @@ func TestCheck(t *testing.T) { pullRequests: testPullRequests, files: [][]string{}, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[14], testPullRequests[14].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[13], testPullRequests[13].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[12], testPullRequests[12].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[11], testPullRequests[11].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[4], testPullRequests[4].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), }, @@ -150,6 +163,10 @@ func TestCheck(t *testing.T) { version: resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), pullRequests: testPullRequests, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[14], testPullRequests[14].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[13], testPullRequests[13].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[12], testPullRequests[12].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[11], testPullRequests[11].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), @@ -172,6 +189,16 @@ func TestCheck(t *testing.T) { version: resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), pullRequests: testPullRequests, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[14], testPullRequests[14].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[13], testPullRequests[13].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[12], testPullRequests[12].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[11], testPullRequests[11].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[4], testPullRequests[4].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), }, }, @@ -186,6 +213,16 @@ func TestCheck(t *testing.T) { version: resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), pullRequests: testPullRequests, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[14], testPullRequests[14].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[13], testPullRequests[13].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[12], testPullRequests[12].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[11], testPullRequests[11].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[4], testPullRequests[4].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[3], testPullRequests[3].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[2], testPullRequests[2].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[1], testPullRequests[1].Tip.CommittedDate.Time), }, @@ -201,6 +238,10 @@ func TestCheck(t *testing.T) { version: resource.NewVersion(testPullRequests[5], testPullRequests[5].Tip.CommittedDate.Time), pullRequests: testPullRequests, expected: resource.CheckResponse{ + resource.NewVersion(testPullRequests[14], testPullRequests[14].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[13], testPullRequests[13].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[12], testPullRequests[12].Tip.CommittedDate.Time), + resource.NewVersion(testPullRequests[11], testPullRequests[11].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[8], testPullRequests[8].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[7], testPullRequests[7].Tip.CommittedDate.Time), resource.NewVersion(testPullRequests[6], testPullRequests[6].Tip.CommittedDate.Time),