0
Fork 0
mirror of https://github.com/project-zot/zot.git synced 2025-01-06 22:40:28 -05:00
zot/pkg/extensions/search/pagination/pagination_test.go
Andrei Aaron bcdd9988f5
fix(cve): cummulative fixes and improvements for CVE scanning logic (#1810)
1. Only scan CVEs for images returned by graphql calls
Since pagination was refactored to account for image indexes, we had started
to run the CVE scanner before pagination was applied, resulting in
decreased ZOT performance if CVE information was requested

2. Increase in medory-cache of cve results to 1m, from 10k digests.

3. Update CVE model to use CVSS severity values in our code.
Previously we relied upon the strings returned by trivy directly,
and the sorting they implemented.
Since CVE severities are standardized, we don't need to pass around
an adapter object just for pagination and sorting purposes anymore.
This also improves our testing since we don't mock the sorting functions anymore.

4. Fix a flaky CLI test not waiting for the zot service to start.

5. Add the search build label on search/cve tests which were missing it.

6. The boltdb update method was used in a few places where view was supposed to be called.

7. Add logs for start and finish of parsing MetaDB.

8. Avoid unmarshalling twice to obtain annotations for multiarch images.

Signed-off-by: Andrei Aaron <aaaron@luxoft.com>
2023-09-17 15:12:20 -07:00

296 lines
8.6 KiB
Go

//go:build search
package pagination_test
import (
"testing"
"time"
. "github.com/smartystreets/goconvey/convey"
"zotregistry.io/zot/pkg/extensions/search/gql_generated"
"zotregistry.io/zot/pkg/extensions/search/pagination"
)
func TestImgSumPagination(t *testing.T) {
Convey("NewImgSumPageFinder errors", t, func() {
_, err := pagination.NewImgSumPageFinder(-1, 0, pagination.AlphabeticAsc)
So(err, ShouldNotBeNil)
_, err = pagination.NewImgSumPageFinder(0, -1, pagination.AlphabeticAsc)
So(err, ShouldNotBeNil)
_, err = pagination.NewImgSumPageFinder(0, 0, "unknown")
So(err, ShouldNotBeNil)
})
Convey("Sort Functions", t, func() {
Convey("ImgSortByAlphabeticAsc", func() {
// Case: repo1 is < repo2
pageBuff := []*gql_generated.ImageSummary{
{RepoName: ref("repo1:1")},
{RepoName: ref("repo2:2")},
}
sortFunc := pagination.ImgSortByAlphabeticAsc(pageBuff)
So(sortFunc(0, 1), ShouldBeTrue)
})
Convey("ImgSortByAlphabeticDsc", func() {
// Case: repo1 is < repo2
pageBuff := []*gql_generated.ImageSummary{
{RepoName: ref("repo1:1")},
{RepoName: ref("repo2:2")},
}
sortFunc := pagination.ImgSortByAlphabeticDsc(pageBuff)
So(sortFunc(0, 1), ShouldBeFalse)
})
Convey("ImgSortByRelevance", func() {
// Case: repo1 is < repo2
pageBuff := []*gql_generated.ImageSummary{
{RepoName: ref("repo1:1")},
{RepoName: ref("repo2:2")},
}
sortFunc := pagination.ImgSortByRelevance(pageBuff)
So(sortFunc(0, 1), ShouldBeTrue)
})
})
}
func TestRepoSumPagination(t *testing.T) {
Convey("NewRepoSumPageFinder errors", t, func() {
_, err := pagination.NewRepoSumPageFinder(-1, 0, pagination.AlphabeticAsc)
So(err, ShouldNotBeNil)
_, err = pagination.NewRepoSumPageFinder(0, -1, pagination.AlphabeticAsc)
So(err, ShouldNotBeNil)
_, err = pagination.NewRepoSumPageFinder(0, 0, "unknown")
So(err, ShouldNotBeNil)
})
}
func ref[T any](input T) *T {
obj := input
return &obj
}
func TestPagination(t *testing.T) {
Convey("Image Pagination", t, func() {
Convey("Sort functions", func() {
imgSum1 := gql_generated.ImageSummary{
RepoName: ref("1"),
Tag: ref("1"),
LastUpdated: ref(time.Date(2010, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(33),
}
imgSum2 := gql_generated.ImageSummary{
RepoName: ref("1"),
Tag: ref("latest"),
LastUpdated: ref(time.Date(2020, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(11),
}
imgSum3 := gql_generated.ImageSummary{
RepoName: ref("3"),
Tag: ref("1"),
LastUpdated: ref(time.Date(2011, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(22),
}
imgSum4 := gql_generated.ImageSummary{
RepoName: ref("4"),
Tag: ref("latest"),
LastUpdated: ref(time.Date(2012, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(44),
}
// ImgSortByAlphabeticAsc
imagePageFinder, err := pagination.NewImgSumPageFinder(4, 0, pagination.AlphabeticAsc)
So(err, ShouldBeNil)
imagePageFinder.Add(&imgSum1)
imagePageFinder.Add(&imgSum2)
imagePageFinder.Add(&imgSum3)
imagePageFinder.Add(&imgSum4)
page, _ := imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.ImageSummary{
&imgSum1, &imgSum2, &imgSum3, &imgSum4,
})
// ImgSortByAlphabeticDsc
imagePageFinder, err = pagination.NewImgSumPageFinder(4, 0, pagination.AlphabeticDsc)
So(err, ShouldBeNil)
imagePageFinder.Add(&imgSum1)
imagePageFinder.Add(&imgSum2)
imagePageFinder.Add(&imgSum3)
imagePageFinder.Add(&imgSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.ImageSummary{
&imgSum4, &imgSum3, &imgSum2, &imgSum1,
})
// ImgSortByRelevance
imagePageFinder, err = pagination.NewImgSumPageFinder(4, 0, pagination.Relevance)
So(err, ShouldBeNil)
imagePageFinder.Add(&imgSum1)
imagePageFinder.Add(&imgSum2)
imagePageFinder.Add(&imgSum3)
imagePageFinder.Add(&imgSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.ImageSummary{
&imgSum1, &imgSum2, &imgSum3, &imgSum4,
})
// ImgSortByUpdateTime
imagePageFinder, err = pagination.NewImgSumPageFinder(4, 0, pagination.UpdateTime)
So(err, ShouldBeNil)
imagePageFinder.Add(&imgSum1)
imagePageFinder.Add(&imgSum2)
imagePageFinder.Add(&imgSum3)
imagePageFinder.Add(&imgSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.ImageSummary{
&imgSum2, &imgSum1, &imgSum4, &imgSum3,
})
// ImgSortByDownloads
imagePageFinder, err = pagination.NewImgSumPageFinder(4, 0, pagination.Downloads)
So(err, ShouldBeNil)
imagePageFinder.Add(&imgSum1)
imagePageFinder.Add(&imgSum2)
imagePageFinder.Add(&imgSum3)
imagePageFinder.Add(&imgSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.ImageSummary{
&imgSum4, &imgSum1, &imgSum3, &imgSum2,
})
})
Convey("Errors", func() {
imagePageFinder, err := pagination.NewImgSumPageFinder(2, 0, "")
So(err, ShouldBeNil)
So(imagePageFinder, ShouldNotBeNil)
_, err = pagination.NewImgSumPageFinder(-1, 0, "")
So(err, ShouldNotBeNil)
_, err = pagination.NewImgSumPageFinder(1, -1, "")
So(err, ShouldNotBeNil)
_, err = pagination.NewImgSumPageFinder(1, -1, "bad sort func")
So(err, ShouldNotBeNil)
})
})
Convey("Repos Pagination", t, func() {
Convey("Sort functions", func() {
repoSum1 := gql_generated.RepoSummary{
Name: ref("1"),
LastUpdated: ref(time.Date(2010, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(33),
Rank: ref(1),
}
repoSum2 := gql_generated.RepoSummary{
Name: ref("2"),
LastUpdated: ref(time.Date(2020, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(11),
Rank: ref(2),
}
repoSum3 := gql_generated.RepoSummary{
Name: ref("3"),
LastUpdated: ref(time.Date(2011, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(22),
Rank: ref(3),
}
repoSum4 := gql_generated.RepoSummary{
Name: ref("4"),
LastUpdated: ref(time.Date(2012, 1, 1, 1, 1, 1, 1, time.UTC)),
DownloadCount: ref(44),
Rank: ref(4),
}
// ImgSortByAlphabeticAsc
imagePageFinder, err := pagination.NewRepoSumPageFinder(4, 0, pagination.AlphabeticAsc)
So(err, ShouldBeNil)
imagePageFinder.Add(&repoSum1)
imagePageFinder.Add(&repoSum2)
imagePageFinder.Add(&repoSum3)
imagePageFinder.Add(&repoSum4)
page, _ := imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.RepoSummary{
&repoSum1, &repoSum2, &repoSum3, &repoSum4,
})
// ImgSortByAlphabeticDsc
imagePageFinder, err = pagination.NewRepoSumPageFinder(4, 0, pagination.AlphabeticDsc)
So(err, ShouldBeNil)
imagePageFinder.Add(&repoSum1)
imagePageFinder.Add(&repoSum2)
imagePageFinder.Add(&repoSum3)
imagePageFinder.Add(&repoSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.RepoSummary{
&repoSum4, &repoSum3, &repoSum2, &repoSum1,
})
// ImgSortByRelevance
imagePageFinder, err = pagination.NewRepoSumPageFinder(4, 0, pagination.Relevance)
So(err, ShouldBeNil)
imagePageFinder.Add(&repoSum1)
imagePageFinder.Add(&repoSum2)
imagePageFinder.Add(&repoSum3)
imagePageFinder.Add(&repoSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.RepoSummary{
&repoSum1, &repoSum2, &repoSum3, &repoSum4,
})
// ImgSortByUpdateTime
imagePageFinder, err = pagination.NewRepoSumPageFinder(4, 0, pagination.UpdateTime)
So(err, ShouldBeNil)
imagePageFinder.Add(&repoSum1)
imagePageFinder.Add(&repoSum2)
imagePageFinder.Add(&repoSum3)
imagePageFinder.Add(&repoSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.RepoSummary{
&repoSum2, &repoSum4, &repoSum3, &repoSum1,
})
// ImgSortByDownloads
imagePageFinder, err = pagination.NewRepoSumPageFinder(4, 0, pagination.Downloads)
So(err, ShouldBeNil)
imagePageFinder.Add(&repoSum1)
imagePageFinder.Add(&repoSum2)
imagePageFinder.Add(&repoSum3)
imagePageFinder.Add(&repoSum4)
page, _ = imagePageFinder.Page()
So(page, ShouldEqual, []*gql_generated.RepoSummary{
&repoSum4, &repoSum1, &repoSum3, &repoSum2,
})
})
Convey("Errors", func() {
repoPageFinder, err := pagination.NewRepoSumPageFinder(2, 0, "")
So(err, ShouldBeNil)
So(repoPageFinder, ShouldNotBeNil)
_, err = pagination.NewRepoSumPageFinder(-1, 0, "")
So(err, ShouldNotBeNil)
_, err = pagination.NewRepoSumPageFinder(1, -1, "")
So(err, ShouldNotBeNil)
_, err = pagination.NewRepoSumPageFinder(1, -1, "bad sort func")
So(err, ShouldNotBeNil)
})
})
}