mirror of
https://github.com/project-zot/zot.git
synced 2024-12-30 22:34:13 -05:00
Fix sync extension logging (#2537)
* fix: nil pointer dereference on localimagestore fixes https://github.com/project-zot/zot/issues/2527 Signed-off-by: Anders Bennedsgaard <abbennedsgaard@gmail.com> * fix: no logging from sync extension imagestore Signed-off-by: Anders Bennedsgaard <abbennedsgaard@gmail.com> * feat: create local imagestore not found error Signed-off-by: Anders Bennedsgaard <abbennedsgaard@gmail.com> * fix: add test Signed-off-by: Anders Bennedsgaard <abbennedsgaard@gmail.com> --------- Signed-off-by: Anders Bennedsgaard <abbennedsgaard@gmail.com>
This commit is contained in:
parent
e5eacaa082
commit
8262c46ad7
5 changed files with 22 additions and 9 deletions
|
@ -87,6 +87,7 @@ var (
|
||||||
ErrDuplicateConfigName = errors.New("cli config name already added")
|
ErrDuplicateConfigName = errors.New("cli config name already added")
|
||||||
ErrInvalidRoute = errors.New("invalid route prefix")
|
ErrInvalidRoute = errors.New("invalid route prefix")
|
||||||
ErrImgStoreNotFound = errors.New("image store not found corresponding to given route")
|
ErrImgStoreNotFound = errors.New("image store not found corresponding to given route")
|
||||||
|
ErrLocalImgStoreNotFound = errors.New("local image store not found corresponding to given route")
|
||||||
ErrEmptyValue = errors.New("empty cache value")
|
ErrEmptyValue = errors.New("empty cache value")
|
||||||
ErrEmptyRepoList = errors.New("no repository found")
|
ErrEmptyRepoList = errors.New("no repository found")
|
||||||
ErrCVESearchDisabled = errors.New("cve search is disabled")
|
ErrCVESearchDisabled = errors.New("cve search is disabled")
|
||||||
|
|
|
@ -92,7 +92,7 @@ func (registry *DestinationRegistry) GetImageReference(repo, reference string) (
|
||||||
func (registry *DestinationRegistry) CommitImage(imageReference types.ImageReference, repo, reference string) error {
|
func (registry *DestinationRegistry) CommitImage(imageReference types.ImageReference, repo, reference string) error {
|
||||||
imageStore := registry.storeController.GetImageStore(repo)
|
imageStore := registry.storeController.GetImageStore(repo)
|
||||||
|
|
||||||
tempImageStore := getImageStoreFromImageReference(imageReference, repo, reference)
|
tempImageStore := getImageStoreFromImageReference(imageReference, repo, reference, registry.log)
|
||||||
|
|
||||||
defer os.RemoveAll(tempImageStore.RootDir())
|
defer os.RemoveAll(tempImageStore.RootDir())
|
||||||
|
|
||||||
|
@ -282,11 +282,11 @@ func (registry *DestinationRegistry) copyBlob(repo string, blobDigest digest.Dig
|
||||||
}
|
}
|
||||||
|
|
||||||
// use only with local imageReferences.
|
// use only with local imageReferences.
|
||||||
func getImageStoreFromImageReference(imageReference types.ImageReference, repo, reference string,
|
func getImageStoreFromImageReference(imageReference types.ImageReference, repo, reference string, log log.Logger,
|
||||||
) storageTypes.ImageStore {
|
) storageTypes.ImageStore {
|
||||||
tmpRootDir := getTempRootDirFromImageReference(imageReference, repo, reference)
|
tmpRootDir := getTempRootDirFromImageReference(imageReference, repo, reference)
|
||||||
|
|
||||||
return getImageStore(tmpRootDir)
|
return getImageStore(tmpRootDir, log)
|
||||||
}
|
}
|
||||||
|
|
||||||
func getTempRootDirFromImageReference(imageReference types.ImageReference, repo, reference string) string {
|
func getTempRootDirFromImageReference(imageReference types.ImageReference, repo, reference string) string {
|
||||||
|
@ -301,8 +301,8 @@ func getTempRootDirFromImageReference(imageReference types.ImageReference, repo,
|
||||||
return tmpRootDir
|
return tmpRootDir
|
||||||
}
|
}
|
||||||
|
|
||||||
func getImageStore(rootDir string) storageTypes.ImageStore {
|
func getImageStore(rootDir string, log log.Logger) storageTypes.ImageStore {
|
||||||
metrics := monitoring.NewMetricsServer(false, log.Logger{})
|
metrics := monitoring.NewMetricsServer(false, log)
|
||||||
|
|
||||||
return local.NewImageStore(rootDir, false, false, log.Logger{}, metrics, nil, nil)
|
return local.NewImageStore(rootDir, false, false, log, metrics, nil, nil)
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,6 +12,7 @@ import (
|
||||||
"github.com/containers/image/v5/types"
|
"github.com/containers/image/v5/types"
|
||||||
"github.com/gofrs/uuid"
|
"github.com/gofrs/uuid"
|
||||||
|
|
||||||
|
zerr "zotregistry.dev/zot/errors"
|
||||||
"zotregistry.dev/zot/pkg/extensions/sync/constants"
|
"zotregistry.dev/zot/pkg/extensions/sync/constants"
|
||||||
"zotregistry.dev/zot/pkg/storage"
|
"zotregistry.dev/zot/pkg/storage"
|
||||||
storageConstants "zotregistry.dev/zot/pkg/storage/constants"
|
storageConstants "zotregistry.dev/zot/pkg/storage/constants"
|
||||||
|
@ -40,6 +41,9 @@ func (oci OciLayoutStorageImpl) GetContext() *types.SystemContext {
|
||||||
|
|
||||||
func (oci OciLayoutStorageImpl) GetImageReference(repo string, reference string) (types.ImageReference, error) {
|
func (oci OciLayoutStorageImpl) GetImageReference(repo string, reference string) (types.ImageReference, error) {
|
||||||
localImageStore := oci.storeController.GetImageStore(repo)
|
localImageStore := oci.storeController.GetImageStore(repo)
|
||||||
|
if localImageStore == nil {
|
||||||
|
return nil, zerr.ErrLocalImgStoreNotFound
|
||||||
|
}
|
||||||
tempSyncPath := path.Join(localImageStore.RootDir(), repo, constants.SyncBlobUploadDir)
|
tempSyncPath := path.Join(localImageStore.RootDir(), repo, constants.SyncBlobUploadDir)
|
||||||
|
|
||||||
// create session folder
|
// create session folder
|
||||||
|
|
|
@ -83,7 +83,7 @@ func New(
|
||||||
service.destination = NewDestinationRegistry(
|
service.destination = NewDestinationRegistry(
|
||||||
storeController,
|
storeController,
|
||||||
storage.StoreController{
|
storage.StoreController{
|
||||||
DefaultStore: getImageStore(tmpDir),
|
DefaultStore: getImageStore(tmpDir, log),
|
||||||
},
|
},
|
||||||
metadb,
|
metadb,
|
||||||
log,
|
log,
|
||||||
|
|
|
@ -83,6 +83,14 @@ func TestInjectSyncUtils(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestNilDefaultStore(t *testing.T) {
|
||||||
|
Convey("Nil default store", t, func() {
|
||||||
|
ols := NewOciLayoutStorage(storage.StoreController{})
|
||||||
|
_, err := ols.GetImageReference(testImage, testImageTag)
|
||||||
|
So(err, ShouldEqual, zerr.ErrLocalImgStoreNotFound)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func TestSyncInternal(t *testing.T) {
|
func TestSyncInternal(t *testing.T) {
|
||||||
Convey("Verify parseRepositoryReference func", t, func() {
|
Convey("Verify parseRepositoryReference func", t, func() {
|
||||||
repositoryReference := fmt.Sprintf("%s/%s", host, testImage)
|
repositoryReference := fmt.Sprintf("%s/%s", host, testImage)
|
||||||
|
@ -214,7 +222,7 @@ func TestDestinationRegistry(t *testing.T) {
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
So(imageReference, ShouldNotBeNil)
|
So(imageReference, ShouldNotBeNil)
|
||||||
|
|
||||||
imgStore := getImageStoreFromImageReference(imageReference, repoName, "1.0")
|
imgStore := getImageStoreFromImageReference(imageReference, repoName, "1.0", log)
|
||||||
|
|
||||||
// create a blob/layer
|
// create a blob/layer
|
||||||
upload, err := imgStore.NewBlobUpload(repoName)
|
upload, err := imgStore.NewBlobUpload(repoName)
|
||||||
|
@ -393,7 +401,7 @@ func TestDestinationRegistry(t *testing.T) {
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
So(imageReference, ShouldNotBeNil)
|
So(imageReference, ShouldNotBeNil)
|
||||||
|
|
||||||
imgStore := getImageStoreFromImageReference(imageReference, repoName, "2.0")
|
imgStore := getImageStoreFromImageReference(imageReference, repoName, "2.0", log)
|
||||||
|
|
||||||
// upload image
|
// upload image
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue