Skip to content

Commit

Permalink
Paginate repository list for an exhaustive search
Browse files Browse the repository at this point in the history
  • Loading branch information
idoru authored and Nishad Mathur committed Sep 13, 2023
1 parent 49ab70f commit b3b6e83
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 21 deletions.
24 changes: 22 additions & 2 deletions gcp/artifacts/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package artifacts

import (
"fmt"
"time"

gcpartifact "google.golang.org/api/artifactregistry/v1"
"google.golang.org/api/googleapi"
Expand All @@ -25,9 +26,28 @@ func NewClient(project string, service *gcpartifact.Service, logger logger) clie
}
}

func (c client) ListRepositories(region string) (*gcpartifact.ListRepositoriesResponse, error) {
func (c client) ListRepositories(region string) ([]*gcpartifact.Repository, error) {
parent := fmt.Sprintf("projects/%v/locations/%v", c.project, region)
return c.repositories.List(parent).Do()
var token string
var list []*gcpartifact.Repository

for {
resp, err := c.repositories.List(parent).PageToken(token).Do()
if err != nil {
return nil, err
}

list = append(list, resp.Repositories...)

token = resp.NextPageToken
if token == "" {
break
}

time.Sleep(time.Second)
}

return list, nil
}

func (c client) DeleteRepository(name string) error {
Expand Down
6 changes: 3 additions & 3 deletions gcp/artifacts/fakes/repositories_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,10 @@ type RepositoriesClient struct {
Region string
}
Returns struct {
ListRepositoriesResponse *artifactregistry.ListRepositoriesResponse
ListRepositoriesResponse []*artifactregistry.Repository
Error error
}
Stub func(string) (*artifactregistry.ListRepositoriesResponse, error)
Stub func(string) ([]*artifactregistry.Repository, error)
}
}

Expand All @@ -42,7 +42,7 @@ func (f *RepositoriesClient) DeleteRepository(param1 string) error {
}
return f.DeleteRepositoryCall.Returns.Error
}
func (f *RepositoriesClient) ListRepositories(param1 string) (*artifactregistry.ListRepositoriesResponse, error) {
func (f *RepositoriesClient) ListRepositories(param1 string) ([]*artifactregistry.Repository, error) {
f.ListRepositoriesCall.mutex.Lock()
defer f.ListRepositoriesCall.mutex.Unlock()
f.ListRepositoriesCall.CallCount++
Expand Down
10 changes: 4 additions & 6 deletions gcp/artifacts/repositories.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,9 @@ package artifacts

import (
"fmt"
"strings"

"github.com/genevieve/leftovers/common"
gcpartifact "google.golang.org/api/artifactregistry/v1"
"strings"
)

type Repositories struct {
Expand All @@ -16,7 +15,7 @@ type Repositories struct {

//go:generate faux --interface repositoriesClient --output fakes/repositories_client.go
type repositoriesClient interface {
ListRepositories(region string) (*gcpartifact.ListRepositoriesResponse, error)
ListRepositories(region string) ([]*gcpartifact.Repository, error)
DeleteRepository(cluster string) error
}

Expand All @@ -31,13 +30,12 @@ func NewRepositories(client repositoriesClient, logger logger, regions map[strin
func (c Repositories) List(filter string) ([]common.Deletable, error) {
repositories := []*gcpartifact.Repository{}
for _, region := range c.regions {
c.logger.Debugf("Listing Repositories for region %s...\n", region)
l, err := c.client.ListRepositories(region)
repositoryList, err := c.client.ListRepositories(region)
if err != nil {
return nil, fmt.Errorf("list repositories for region %v: %w", region, err)
}

repositories = append(repositories, l.Repositories...)
repositories = append(repositories, repositoryList...)
}

deletables := []common.Deletable{}
Expand Down
16 changes: 6 additions & 10 deletions gcp/artifacts/repositories_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,9 @@ var _ = Describe("Clusters", func() {

Describe("List", func() {
BeforeEach(func() {
client.ListRepositoriesCall.Returns.ListRepositoriesResponse = &gcpartifact.ListRepositoriesResponse{
Repositories: []*gcpartifact.Repository{{
Name: "banana-repository",
}},
}
client.ListRepositoriesCall.Returns.ListRepositoriesResponse = []*gcpartifact.Repository{{
Name: "banana-repository",
}}
})

It("returns a list of clusters to delete", func() {
Expand Down Expand Up @@ -64,11 +62,9 @@ var _ = Describe("Clusters", func() {

Context("when the resource name does not contain the filter", func() {
BeforeEach(func() {
client.ListRepositoriesCall.Returns.ListRepositoriesResponse = &gcpartifact.ListRepositoriesResponse{
Repositories: []*gcpartifact.Repository{{
Name: "kiwi-repository",
}},
}
client.ListRepositoriesCall.Returns.ListRepositoriesResponse = []*gcpartifact.Repository{{
Name: "kiwi-repository",
}}
})

It("does not return the resource in the list", func() {
Expand Down

0 comments on commit b3b6e83

Please sign in to comment.