From 12c7cb3b23eb56d18d8b44769933768f20f8ebad Mon Sep 17 00:00:00 2001 From: Andrew Dewar Date: Fri, 27 Oct 2023 12:29:40 -0600 Subject: [PATCH] Fixes 2702,Fixes 2887: Add orgID to snapshot list endpoint --- pkg/dao/interfaces.go | 2 +- pkg/dao/repository_configs.go | 34 +++++++++---- pkg/dao/rpms.go | 11 +++- pkg/dao/rpms_test.go | 61 ++++++++++++++++++++++ pkg/dao/snapshots.go | 29 ++++++++--- pkg/dao/snapshots_mock.go | 26 +++++----- pkg/dao/snapshots_test.go | 84 +++++++++++++++++++++++++++++-- pkg/handler/snapshots.go | 2 +- pkg/handler/snapshots_test.go | 2 +- test/integration/snapshot_test.go | 8 +-- 10 files changed, 213 insertions(+), 46 deletions(-) diff --git a/pkg/dao/interfaces.go b/pkg/dao/interfaces.go index 188f3581d..2f1747f69 100644 --- a/pkg/dao/interfaces.go +++ b/pkg/dao/interfaces.go @@ -79,7 +79,7 @@ type RepositoryDao interface { //go:generate mockery --name SnapshotDao --filename snapshots_mock.go --inpackage type SnapshotDao interface { Create(snap *models.Snapshot) error - List(repoConfigUuid string, paginationData api.PaginationData, _ api.FilterData) (api.SnapshotCollectionResponse, int64, error) + List(orgID string, repoConfigUuid string, paginationData api.PaginationData, filterData api.FilterData) (api.SnapshotCollectionResponse, int64, error) FetchForRepoConfigUUID(repoConfigUUID string) ([]models.Snapshot, error) Delete(snapUUID string) error FetchLatestSnapshot(repoConfigUUID string) (api.SnapshotResponse, error) diff --git a/pkg/dao/repository_configs.go b/pkg/dao/repository_configs.go index 0a479529c..e52bec89d 100644 --- a/pkg/dao/repository_configs.go +++ b/pkg/dao/repository_configs.go @@ -90,6 +90,11 @@ func (r *repositoryConfigDaoImpl) InitializePulpClient(ctx context.Context, orgI func (r repositoryConfigDaoImpl) Create(newRepoReq api.RepositoryRequest) (api.RepositoryResponse, error) { var newRepo models.Repository var newRepoConfig models.RepositoryConfiguration + + if newRepoConfig.OrgID == config.RedHatOrg { + return api.RepositoryResponse{}, errors.New("Creating of Red Hat repositories is not permitted") + } + ApiFieldsToModel(newRepoReq, &newRepoConfig, &newRepo) cleanedUrl := models.CleanupURL(newRepo.URL) @@ -110,7 +115,7 @@ func (r repositoryConfigDaoImpl) Create(newRepoReq api.RepositoryRequest) (api.R } // reload the repoConfig to fetch repository info too - newRepoConfig, err := r.fetchRepoConfig(newRepoConfig.OrgID, newRepoConfig.UUID) + newRepoConfig, err := r.fetchRepoConfig(newRepoConfig.OrgID, newRepoConfig.UUID, false) if err != nil { return api.RepositoryResponse{}, DBErrorToApi(err) } @@ -362,7 +367,7 @@ func (r repositoryConfigDaoImpl) InternalOnly_FetchRepoConfigsForRepoUUID(uuid s func (r repositoryConfigDaoImpl) Fetch(orgID string, uuid string) (api.RepositoryResponse, error) { var repo api.RepositoryResponse - repoConfig, err := r.fetchRepoConfig(orgID, uuid) + repoConfig, err := r.fetchRepoConfig(orgID, uuid, true) if err != nil { return api.RepositoryResponse{}, err } @@ -383,19 +388,26 @@ func (r repositoryConfigDaoImpl) Fetch(orgID string, uuid string) (api.Repositor return repo, nil } -func (r repositoryConfigDaoImpl) fetchRepoConfig(orgID string, uuid string) (models.RepositoryConfiguration, error) { +// fetchRepConfig: "any" allows the fetching of red_hat repositories +func (r repositoryConfigDaoImpl) fetchRepoConfig(orgID string, uuid string, any bool) (models.RepositoryConfiguration, error) { found := models.RepositoryConfiguration{} + + orgIdsToCheck := []string{orgID} + + if any { + orgIdsToCheck = append(orgIdsToCheck, config.RedHatOrg) + } + result := r.db. Preload("Repository").Preload("LastSnapshot"). - Where("UUID = ? AND ORG_ID = ?", UuidifyString(uuid), orgID). + Where("UUID = ? AND ORG_ID IN ?", UuidifyString(uuid), orgIdsToCheck). First(&found) if result.Error != nil { if result.Error == gorm.ErrRecordNotFound { return found, &ce.DaoError{NotFound: true, Message: "Could not find repository with UUID " + uuid} - } else { - return found, DBErrorToApi(result.Error) } + return found, DBErrorToApi(result.Error) } return found, nil } @@ -413,9 +425,8 @@ func (r repositoryConfigDaoImpl) FetchByRepoUuid(orgID string, repoUuid string) if result.Error != nil { if result.Error == gorm.ErrRecordNotFound { return repo, &ce.DaoError{NotFound: true, Message: "Could not find repository with UUID " + repoUuid} - } else { - return repo, DBErrorToApi(result.Error) } + return repo, DBErrorToApi(result.Error) } ModelToApiFields(repoConfig, &repo) @@ -431,7 +442,8 @@ func (r repositoryConfigDaoImpl) Update(orgID, uuid string, repoParams api.Repos // We are updating the repo config & snapshots, so bundle in a transaction err = r.db.Transaction(func(tx *gorm.DB) error { - if repoConfig, err = r.fetchRepoConfig(orgID, uuid); err != nil { + // Setting "any" to false here to prevent updating red_hat repositories + if repoConfig, err = r.fetchRepoConfig(orgID, uuid, false); err != nil { return err } ApiFieldsToModel(repoParams, &repoConfig, &repo) @@ -522,7 +534,7 @@ func (r repositoryConfigDaoImpl) SoftDelete(orgID string, uuid string) error { var repoConfig models.RepositoryConfiguration var err error - if repoConfig, err = r.fetchRepoConfig(orgID, uuid); err != nil { + if repoConfig, err = r.fetchRepoConfig(orgID, uuid, false); err != nil { return err } @@ -583,7 +595,7 @@ func (r repositoryConfigDaoImpl) bulkDelete(tx *gorm.DB, orgID string, uuids []s var err error var repoConfig models.RepositoryConfiguration - if repoConfig, err = r.fetchRepoConfig(orgID, uuids[i]); err != nil { + if repoConfig, err = r.fetchRepoConfig(orgID, uuids[i], false); err != nil { dbErr = DBErrorToApi(err) errors[i] = dbErr tx.RollbackTo(save) diff --git a/pkg/dao/rpms.go b/pkg/dao/rpms.go index 2aa5d23c2..2d09dbd4d 100644 --- a/pkg/dao/rpms.go +++ b/pkg/dao/rpms.go @@ -5,6 +5,7 @@ import ( "strings" "github.com/content-services/content-sources-backend/pkg/api" + "github.com/content-services/content-sources-backend/pkg/config" ce "github.com/content-services/content-sources-backend/pkg/errors" "github.com/content-services/content-sources-backend/pkg/models" "github.com/content-services/yummy/pkg/yum" @@ -28,7 +29,7 @@ func (r rpmDaoImpl) isOwnedRepository(orgID string, repositoryConfigUUID string) var repoConfigs []models.RepositoryConfiguration var count int64 if err := r.db. - Where("org_id = ? and uuid = ?", orgID, UuidifyString(repositoryConfigUUID)). + Where("org_id IN (?, ?) AND uuid = ?", orgID, config.RedHatOrg, UuidifyString(repositoryConfigUUID)). Find(&repoConfigs). Count(&count). Error; err != nil { @@ -40,7 +41,13 @@ func (r rpmDaoImpl) isOwnedRepository(orgID string, repositoryConfigUUID string) return true, nil } -func (r rpmDaoImpl) List(orgID string, repositoryConfigUUID string, limit int, offset int, search string, sortBy string) (api.RepositoryRpmCollectionResponse, int64, error) { +func (r rpmDaoImpl) List( + orgID string, + repositoryConfigUUID string, + limit int, offset int, + search string, + sortBy string, +) (api.RepositoryRpmCollectionResponse, int64, error) { // Check arguments if orgID == "" { return api.RepositoryRpmCollectionResponse{}, 0, fmt.Errorf("orgID can not be an empty string") diff --git a/pkg/dao/rpms_test.go b/pkg/dao/rpms_test.go index 5815a1a94..9707a8f3e 100644 --- a/pkg/dao/rpms_test.go +++ b/pkg/dao/rpms_test.go @@ -109,6 +109,67 @@ func (s *RpmSuite) TestRpmList() { assert.Equal(t, count, int64(0)) } +func (s *RpmSuite) TestRpmListRedHatRepositories() { + var err error + t := s.Suite.T() + + redHatRepo := repoPublicTest.DeepCopy() + redHatRepo.URL = "https://www.public.redhat.com" + if err := s.tx.Create(redHatRepo).Error; err != nil { + s.FailNow("Preparing Repository record: %w", err) + } + + redhatRepoConfig := repoConfigTest1.DeepCopy() + redhatRepoConfig.OrgID = config.RedHatOrg + redhatRepoConfig.Name = "Demo Redhat Repository Config" + redhatRepoConfig.RepositoryUUID = redHatRepo.Base.UUID + if err := s.tx.Create(redhatRepoConfig).Error; err != nil { + s.FailNow("Preparing RepositoryConfiguration record: %w", err) + } + + // Prepare RepositoryRpm records + rpm1 := repoRpmTest1.DeepCopy() + rpm2 := repoRpmTest2.DeepCopy() + dao := GetRpmDao(s.tx) + + err = s.tx.Create(&rpm1).Error + assert.NoError(t, err) + err = s.tx.Create(&rpm2).Error + assert.NoError(t, err) + + // Add one red hat repo + err = s.tx.Create(&models.RepositoryRpm{ + RepositoryUUID: redHatRepo.Base.UUID, + RpmUUID: rpm1.Base.UUID, + }).Error + assert.NoError(t, err) + + //Add one regular repository + err = s.tx.Create(&models.RepositoryRpm{ + RepositoryUUID: s.repo.Base.UUID, + RpmUUID: rpm2.Base.UUID, + }).Error + + assert.NoError(t, err) + + var repoRpmList api.RepositoryRpmCollectionResponse + var count int64 + + // Check red hat repo package (matched "-1" orgID) + repoRpmList, count, err = dao.List("ThisOrgIdWontMatter", redhatRepoConfig.Base.UUID, 10, 0, "", "") + assert.NoError(t, err) + assert.Equal(t, int64(1), count) + assert.Equal(t, repoRpmList.Meta.Count, count) + assert.Equal(t, repoRpmTest1.Name, repoRpmList.Data[0].Name) // Asserts name:asc by default + + // Check custom repo package (checks orgId) + repoRpmList, count, err = dao.List(orgIDTest, s.repoConfig.Base.UUID, 10, 0, "", "") + assert.NoError(t, err) + assert.Equal(t, int64(1), count) + assert.Equal(t, repoRpmList.Meta.Count, count) + assert.Equal(t, repoRpmTest2.Name, repoRpmList.Data[0].Name) // Asserts name:asc by default +} + func (s *RpmSuite) TestRpmListRepoNotFound() { t := s.Suite.T() dao := GetRpmDao(s.tx) diff --git a/pkg/dao/snapshots.go b/pkg/dao/snapshots.go index 42daf504f..14961d529 100644 --- a/pkg/dao/snapshots.go +++ b/pkg/dao/snapshots.go @@ -6,6 +6,7 @@ import ( "strings" "github.com/content-services/content-sources-backend/pkg/api" + "github.com/content-services/content-sources-backend/pkg/config" ce "github.com/content-services/content-sources-backend/pkg/errors" "github.com/content-services/content-sources-backend/pkg/models" "github.com/content-services/content-sources-backend/pkg/pulp_client" @@ -48,17 +49,28 @@ func (sDao *snapshotDaoImpl) Create(s *models.Snapshot) error { } // List the snapshots for a given repository config -func (sDao *snapshotDaoImpl) List(repoConfigUuid string, paginationData api.PaginationData, _ api.FilterData) (api.SnapshotCollectionResponse, int64, error) { +func (sDao *snapshotDaoImpl) List( + orgID string, + repoConfigUUID string, + paginationData api.PaginationData, + _ api.FilterData, +) (api.SnapshotCollectionResponse, int64, error) { var snaps []models.Snapshot var totalSnaps int64 var repoConfig models.RepositoryConfiguration // First check if repo config exists - result := sDao.db.Where("uuid = ?", UuidifyString(repoConfigUuid)).First(&repoConfig) + result := sDao.db.Where( + "repository_configurations.org_id IN (?,?) AND uuid = ?", + orgID, + config.RedHatOrg, + UuidifyString(repoConfigUUID)). + First(&repoConfig) + if result.Error != nil { if result.Error == gorm.ErrRecordNotFound { return api.SnapshotCollectionResponse{}, totalSnaps, &ce.DaoError{ - Message: "Could not find repository with UUID " + repoConfigUuid, + Message: "Could not find repository with UUID " + repoConfigUUID, NotFound: true, } } @@ -71,12 +83,13 @@ func (sDao *snapshotDaoImpl) List(repoConfigUuid string, paginationData api.Pagi order := convertSortByToSQL(paginationData.SortBy, sortMap, "created_at asc") filteredDB := sDao.db. - Where("snapshots.repository_configuration_uuid = ?", UuidifyString(repoConfigUuid)) + Model(&models.Snapshot{}). + Joins("JOIN repository_configurations ON repository_configuration_uuid = repository_configurations.uuid"). + Where("repository_configuration_uuid = ?", UuidifyString(repoConfigUUID)). + Where("repository_configurations.org_id IN (?,?)", orgID, config.RedHatOrg) // Get count - filteredDB. - Model(&snaps). - Count(&totalSnaps) + filteredDB.Count(&totalSnaps) if filteredDB.Error != nil { return api.SnapshotCollectionResponse{}, 0, filteredDB.Error @@ -123,7 +136,7 @@ func (sDao *snapshotDaoImpl) Fetch(uuid string) (models.Snapshot, error) { func (sDao *snapshotDaoImpl) GetRepositoryConfigurationFile(orgID, snapshotUUID, repoConfigUUID string) (string, error) { rcDao := repositoryConfigDaoImpl{db: sDao.db} - repoConfig, err := rcDao.fetchRepoConfig(orgID, repoConfigUUID) + repoConfig, err := rcDao.fetchRepoConfig(orgID, repoConfigUUID, true) if err != nil { return "", err } diff --git a/pkg/dao/snapshots_mock.go b/pkg/dao/snapshots_mock.go index 476066758..f1f59c621 100644 --- a/pkg/dao/snapshots_mock.go +++ b/pkg/dao/snapshots_mock.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.32.0. DO NOT EDIT. +// Code generated by mockery v2.33.0. DO NOT EDIT. package dao @@ -12,7 +12,7 @@ import ( models "github.com/content-services/content-sources-backend/pkg/models" ) -// MockSnapshotDao is an autogenerated mock type for the SnapshotDao type +// MockSnapshotDao is an autogenerated mock type for the MockSnapshotDao type type MockSnapshotDao struct { mock.Mock } @@ -133,30 +133,30 @@ func (_m *MockSnapshotDao) InitializePulpClient(ctx context.Context, orgID strin return r0 } -// List provides a mock function with given fields: repoConfigUuid, paginationData, _a2 -func (_m *MockSnapshotDao) List(repoConfigUuid string, paginationData api.PaginationData, _a2 api.FilterData) (api.SnapshotCollectionResponse, int64, error) { - ret := _m.Called(repoConfigUuid, paginationData, _a2) +// List provides a mock function with given fields: orgID, repoConfigUuid, paginationData, filterData +func (_m *MockSnapshotDao) List(orgID string, repoConfigUuid string, paginationData api.PaginationData, filterData api.FilterData) (api.SnapshotCollectionResponse, int64, error) { + ret := _m.Called(orgID, repoConfigUuid, paginationData, filterData) var r0 api.SnapshotCollectionResponse var r1 int64 var r2 error - if rf, ok := ret.Get(0).(func(string, api.PaginationData, api.FilterData) (api.SnapshotCollectionResponse, int64, error)); ok { - return rf(repoConfigUuid, paginationData, _a2) + if rf, ok := ret.Get(0).(func(string, string, api.PaginationData, api.FilterData) (api.SnapshotCollectionResponse, int64, error)); ok { + return rf(orgID, repoConfigUuid, paginationData, filterData) } - if rf, ok := ret.Get(0).(func(string, api.PaginationData, api.FilterData) api.SnapshotCollectionResponse); ok { - r0 = rf(repoConfigUuid, paginationData, _a2) + if rf, ok := ret.Get(0).(func(string, string, api.PaginationData, api.FilterData) api.SnapshotCollectionResponse); ok { + r0 = rf(orgID, repoConfigUuid, paginationData, filterData) } else { r0 = ret.Get(0).(api.SnapshotCollectionResponse) } - if rf, ok := ret.Get(1).(func(string, api.PaginationData, api.FilterData) int64); ok { - r1 = rf(repoConfigUuid, paginationData, _a2) + if rf, ok := ret.Get(1).(func(string, string, api.PaginationData, api.FilterData) int64); ok { + r1 = rf(orgID, repoConfigUuid, paginationData, filterData) } else { r1 = ret.Get(1).(int64) } - if rf, ok := ret.Get(2).(func(string, api.PaginationData, api.FilterData) error); ok { - r2 = rf(repoConfigUuid, paginationData, _a2) + if rf, ok := ret.Get(2).(func(string, string, api.PaginationData, api.FilterData) error); ok { + r2 = rf(orgID, repoConfigUuid, paginationData, filterData) } else { r2 = ret.Error(2) } diff --git a/pkg/dao/snapshots_test.go b/pkg/dao/snapshots_test.go index 33303075c..84bd3b2b7 100644 --- a/pkg/dao/snapshots_test.go +++ b/pkg/dao/snapshots_test.go @@ -6,6 +6,7 @@ import ( "time" "github.com/content-services/content-sources-backend/pkg/api" + "github.com/content-services/content-sources-backend/pkg/config" ce "github.com/content-services/content-sources-backend/pkg/errors" "github.com/content-services/content-sources-backend/pkg/models" "github.com/content-services/content-sources-backend/pkg/pulp_client" @@ -59,6 +60,29 @@ func (s *SnapshotsSuite) createRepository() models.RepositoryConfiguration { return rConfig } +func (s *SnapshotsSuite) createRedhatRepository() models.RepositoryConfiguration { + t := s.T() + tx := s.tx + + testRepository := models.Repository{ + URL: "https://example.redhat.com", + LastIntrospectionTime: nil, + LastIntrospectionError: nil, + } + err := tx.Create(&testRepository).Error + assert.NoError(t, err) + + rConfig := models.RepositoryConfiguration{ + Name: "redhatSnapshot", + OrgID: config.RedHatOrg, + RepositoryUUID: testRepository.UUID, + } + + err = tx.Create(&rConfig).Error + assert.NoError(t, err) + return rConfig +} + func (s *SnapshotsSuite) createSnapshot(rConfig models.RepositoryConfiguration) models.Snapshot { t := s.T() tx := s.tx @@ -90,6 +114,7 @@ func (s *SnapshotsSuite) TestCreateAndList() { repoDao := repositoryConfigDaoImpl{db: tx, yumRepo: &mockExt.YumRepositoryMock{}} rConfig := s.createRepository() + pageData := api.PaginationData{ Limit: 100, Offset: 0, @@ -102,9 +127,9 @@ func (s *SnapshotsSuite) TestCreateAndList() { snap := s.createSnapshot(rConfig) - collection, total, err := sDao.List(rConfig.UUID, pageData, filterData) + collection, total, err := sDao.List(rConfig.OrgID, rConfig.UUID, pageData, filterData) - repository, _ := repoDao.fetchRepoConfig(rConfig.OrgID, rConfig.UUID) + repository, _ := repoDao.fetchRepoConfig(rConfig.OrgID, rConfig.UUID, false) repositoryList, repoCount, _ := repoDao.List(rConfig.OrgID, api.PaginationData{Limit: -1}, api.FilterData{}) assert.NoError(t, err) @@ -128,6 +153,55 @@ func (s *SnapshotsSuite) TestCreateAndList() { } } +func (s *SnapshotsSuite) TestCreateAndListRedHatRepo() { + t := s.T() + tx := s.tx + + mockPulpClient := pulp_client.NewMockPulpClient(t) + sDao := snapshotDaoImpl{db: tx, pulpClient: mockPulpClient} + mockPulpClient.On("GetContentPath").Return(testContentPath, nil) + + repoDao := repositoryConfigDaoImpl{db: tx, yumRepo: &mockExt.YumRepositoryMock{}} + + redhatRepositoryConfig := s.createRedhatRepository() + redhatSnap := s.createSnapshot(redhatRepositoryConfig) + + pageData := api.PaginationData{ + Limit: 100, + Offset: 0, + } + filterData := api.FilterData{ + Search: "", + Arch: "", + Version: "", + } + + collection, total, err := sDao.List("ShouldNotMatter", redhatRepositoryConfig.UUID, pageData, filterData) + + repository, _ := repoDao.fetchRepoConfig("ShouldNotMatter", redhatRepositoryConfig.UUID, true) + repositoryList, repoCount, _ := repoDao.List("ShouldNotMatter", api.PaginationData{Limit: -1}, api.FilterData{}) + + assert.NoError(t, err) + assert.Equal(t, int64(1), total) + assert.Equal(t, 1, len(collection.Data)) + if len(collection.Data) > 0 { + assert.Equal(t, redhatSnap.RepositoryPath, collection.Data[0].RepositoryPath) + assert.Equal(t, redhatSnap.ContentCounts, models.ContentCountsType(collection.Data[0].ContentCounts)) + assert.Equal(t, redhatSnap.AddedCounts, models.ContentCountsType(collection.Data[0].AddedCounts)) + assert.Equal(t, redhatSnap.RemovedCounts, models.ContentCountsType(collection.Data[0].RemovedCounts)) + assert.False(t, collection.Data[0].CreatedAt.IsZero()) + // Check that the repositoryConfig has the appropriate values + assert.Equal(t, redhatSnap.UUID, repository.LastSnapshotUUID) + assert.EqualValues(t, redhatSnap.AddedCounts, repository.LastSnapshot.AddedCounts) + assert.EqualValues(t, redhatSnap.RemovedCounts, repository.LastSnapshot.RemovedCounts) + // Check that the list repositoryConfig has the appropriate values + assert.Equal(t, int64(1), repoCount) + assert.Equal(t, redhatSnap.UUID, repositoryList.Data[0].LastSnapshotUUID) + assert.EqualValues(t, redhatSnap.AddedCounts, repositoryList.Data[0].LastSnapshot.AddedCounts) + assert.EqualValues(t, redhatSnap.RemovedCounts, repositoryList.Data[0].LastSnapshot.RemovedCounts) + } +} + func (s *SnapshotsSuite) TestListNoSnapshots() { t := s.T() tx := s.tx @@ -161,7 +235,7 @@ func (s *SnapshotsSuite) TestListNoSnapshots() { err = tx.Create(&rConfig).Error assert.NoError(t, err) - collection, total, err := sDao.List(rConfig.UUID, pageData, filterData) + collection, total, err := sDao.List(rConfig.OrgID, rConfig.UUID, pageData, filterData) assert.NoError(t, err) assert.Equal(t, int64(0), total) assert.Equal(t, 0, len(collection.Data)) @@ -190,7 +264,7 @@ func (s *SnapshotsSuite) TestListPageLimit() { s.createSnapshot(rConfig) } - collection, total, err := sDao.List(rConfig.UUID, pageData, filterData) + collection, total, err := sDao.List(rConfig.OrgID, rConfig.UUID, pageData, filterData) assert.NoError(t, err) assert.Equal(t, int64(11), total) assert.Equal(t, 10, len(collection.Data)) @@ -215,7 +289,7 @@ func (s *SnapshotsSuite) TestListNotFound() { s.createSnapshot(rConfig) - collection, total, err := sDao.List("bad-uuid", pageData, filterData) + collection, total, err := sDao.List(rConfig.OrgID, "bad-uuid", pageData, filterData) assert.Error(t, err) daoError, ok := err.(*ce.DaoError) assert.True(t, ok) diff --git a/pkg/handler/snapshots.go b/pkg/handler/snapshots.go index 6193d2102..fe4240e9f 100644 --- a/pkg/handler/snapshots.go +++ b/pkg/handler/snapshots.go @@ -51,7 +51,7 @@ func (sh *SnapshotHandler) listSnapshots(c echo.Context) error { return ce.NewErrorResponse(ce.HttpCodeForDaoError(err), "Error initializing pulp client", err.Error()) } - snapshots, totalSnaps, err := sh.DaoRegistry.Snapshot.List(uuid, pageData, filterData) + snapshots, totalSnaps, err := sh.DaoRegistry.Snapshot.List(orgID, uuid, pageData, filterData) if err != nil { return ce.NewErrorResponse(ce.HttpCodeForDaoError(err), "Error listing repository snapshots", err.Error()) } diff --git a/pkg/handler/snapshots_test.go b/pkg/handler/snapshots_test.go index 77f3bc5e1..1f0bcf455 100644 --- a/pkg/handler/snapshots_test.go +++ b/pkg/handler/snapshots_test.go @@ -66,7 +66,7 @@ func (suite *SnapshotSuite) TestSnapshotList() { uuid := "abcadaba" orgID := test_handler.MockOrgId suite.reg.Snapshot.On("InitializePulpClient", mock.AnythingOfType("*context.valueCtx"), orgID).Return(nil).Once() - suite.reg.Snapshot.On("List", uuid, paginationData, api.FilterData{}).Return(collection, int64(1), nil) + suite.reg.Snapshot.On("List", test_handler.MockOrgId, uuid, paginationData, api.FilterData{}).Return(collection, int64(1), nil) path := fmt.Sprintf("%s/repositories/%s/snapshots/?limit=%d", fullRootPath(), uuid, 10) req := httptest.NewRequest(http.MethodGet, path, nil) diff --git a/test/integration/snapshot_test.go b/test/integration/snapshot_test.go index 10f8132cb..e59d885bf 100644 --- a/test/integration/snapshot_test.go +++ b/test/integration/snapshot_test.go @@ -87,7 +87,7 @@ func (s *SnapshotSuite) TestSnapshot() { s.snapshotAndWait(taskClient, repo, repoUuid, accountId) // Verify the snapshot was created - snaps, _, err := s.dao.Snapshot.List(repo.UUID, api.PaginationData{Limit: -1}, api.FilterData{}) + snaps, _, err := s.dao.Snapshot.List(repo.OrgID, repo.UUID, api.PaginationData{Limit: -1}, api.FilterData{}) assert.NoError(s.T(), err) assert.NotEmpty(s.T(), snaps) time.Sleep(5 * time.Second) @@ -138,7 +138,7 @@ func (s *SnapshotSuite) TestSnapshot() { s.WaitOnTask(taskUuid) // Verify the snapshot was deleted - snaps, _, err = s.dao.Snapshot.List(repo.UUID, api.PaginationData{Limit: -1}, api.FilterData{}) + snaps, _, err = s.dao.Snapshot.List(repo.OrgID, repo.UUID, api.PaginationData{Limit: -1}, api.FilterData{}) assert.Error(s.T(), err) assert.Empty(s.T(), snaps.Data) time.Sleep(5 * time.Second) @@ -185,7 +185,7 @@ func (s *SnapshotSuite) snapshotAndWait(taskClient client.TaskClient, repo api.R s.WaitOnTask(taskUuid) // Verify the snapshot was created - snaps, _, err := s.dao.Snapshot.List(repo.UUID, api.PaginationData{Limit: -1}, api.FilterData{}) + snaps, _, err := s.dao.Snapshot.List(repo.OrgID, repo.UUID, api.PaginationData{Limit: -1}, api.FilterData{}) assert.NoError(s.T(), err) assert.NotEmpty(s.T(), snaps) time.Sleep(5 * time.Second) @@ -211,7 +211,7 @@ func (s *SnapshotSuite) cancelAndWait(taskClient client.TaskClient, taskUUID uui s.WaitOnCanceledTask(taskUUID) // Verify the snapshot was not created - snaps, _, err := s.dao.Snapshot.List(repo.UUID, api.PaginationData{}, api.FilterData{}) + snaps, _, err := s.dao.Snapshot.List(repo.OrgID, repo.UUID, api.PaginationData{}, api.FilterData{}) assert.NoError(s.T(), err) assert.Equal(s.T(), api.SnapshotCollectionResponse{Data: []api.SnapshotResponse{}}, snaps) }