2022-04-27 09:00:20 +03:00
|
|
|
//go:build scrub
|
|
|
|
// +build scrub
|
2022-03-04 09:37:06 +02:00
|
|
|
|
|
|
|
package scrub_test
|
|
|
|
|
|
|
|
import (
|
2023-09-05 19:48:56 +03:00
|
|
|
"context"
|
2022-03-04 09:37:06 +02:00
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
2022-10-20 19:39:20 +03:00
|
|
|
|
2024-02-01 06:34:07 +02:00
|
|
|
"zotregistry.dev/zot/pkg/api"
|
|
|
|
"zotregistry.dev/zot/pkg/api/config"
|
|
|
|
extconf "zotregistry.dev/zot/pkg/extensions/config"
|
|
|
|
"zotregistry.dev/zot/pkg/extensions/monitoring"
|
|
|
|
"zotregistry.dev/zot/pkg/extensions/scrub"
|
|
|
|
"zotregistry.dev/zot/pkg/log"
|
|
|
|
"zotregistry.dev/zot/pkg/storage"
|
|
|
|
"zotregistry.dev/zot/pkg/storage/cache"
|
|
|
|
"zotregistry.dev/zot/pkg/storage/local"
|
|
|
|
test "zotregistry.dev/zot/pkg/test/common"
|
|
|
|
. "zotregistry.dev/zot/pkg/test/image-utils"
|
|
|
|
ociutils "zotregistry.dev/zot/pkg/test/oci-utils"
|
2022-03-04 09:37:06 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
repoName = "test"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestScrubExtension(t *testing.T) {
|
|
|
|
Convey("Blobs integrity not affected", t, func(c C) {
|
|
|
|
port := test.GetFreePort()
|
|
|
|
|
2022-09-02 14:56:02 +02:00
|
|
|
logFile, err := os.CreateTemp("", "zot-log*.txt")
|
2022-03-04 09:37:06 +02:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
defer os.Remove(logFile.Name()) // clean up
|
|
|
|
|
|
|
|
conf := config.New()
|
|
|
|
conf.HTTP.Port = port
|
|
|
|
|
|
|
|
dir := t.TempDir()
|
2022-09-23 08:27:56 +03:00
|
|
|
subdir := t.TempDir()
|
2022-03-04 09:37:06 +02:00
|
|
|
|
|
|
|
conf.Storage.RootDirectory = dir
|
2023-04-07 19:49:24 +03:00
|
|
|
conf.Storage.Dedupe = false
|
2023-08-07 22:55:19 +03:00
|
|
|
conf.Storage.GC = false
|
2023-04-07 19:49:24 +03:00
|
|
|
|
2022-09-23 08:27:56 +03:00
|
|
|
substore := config.StorageConfig{RootDirectory: subdir}
|
|
|
|
conf.Storage.SubPaths = map[string]config.StorageConfig{"/a": substore}
|
2022-03-04 09:37:06 +02:00
|
|
|
conf.Log.Output = logFile.Name()
|
2022-09-28 04:06:50 +03:00
|
|
|
trueValue := true
|
2022-03-04 09:37:06 +02:00
|
|
|
scrubConfig := &extconf.ScrubConfig{
|
2022-10-21 05:33:54 -07:00
|
|
|
BaseConfig: extconf.BaseConfig{Enable: &trueValue},
|
|
|
|
Interval: 2,
|
2022-03-04 09:37:06 +02:00
|
|
|
}
|
|
|
|
conf.Extensions = &extconf.ExtensionConfig{
|
|
|
|
Scrub: scrubConfig,
|
|
|
|
}
|
|
|
|
|
|
|
|
ctlr := api.NewController(conf)
|
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
srcStorageCtlr := ociutils.GetDefaultStoreController(dir, log.NewLogger("debug", ""))
|
|
|
|
err = WriteImageToFileSystem(CreateDefaultVulnerableImage(), repoName, "0.0.1", srcStorageCtlr)
|
2023-08-18 11:46:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
2022-03-04 09:37:06 +02:00
|
|
|
|
2023-01-19 18:54:05 +02:00
|
|
|
cm := test.NewControllerManager(ctlr)
|
|
|
|
cm.StartAndWait(port)
|
|
|
|
defer cm.StopServer()
|
2022-03-04 09:37:06 +02:00
|
|
|
|
2023-12-11 20:00:34 +02:00
|
|
|
found, err := test.ReadLogFileAndSearchString(logFile.Name(), "blobs/manifest ok", 60*time.Second)
|
|
|
|
So(found, ShouldBeTrue)
|
2022-03-04 09:37:06 +02:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Blobs integrity affected", t, func(c C) {
|
|
|
|
port := test.GetFreePort()
|
|
|
|
|
2022-09-02 14:56:02 +02:00
|
|
|
logFile, err := os.CreateTemp("", "zot-log*.txt")
|
2022-03-04 09:37:06 +02:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
defer os.Remove(logFile.Name()) // clean up
|
|
|
|
|
|
|
|
conf := config.New()
|
|
|
|
conf.HTTP.Port = port
|
|
|
|
|
|
|
|
dir := t.TempDir()
|
|
|
|
|
|
|
|
conf.Storage.RootDirectory = dir
|
2023-04-07 19:49:24 +03:00
|
|
|
conf.Storage.Dedupe = false
|
2023-08-07 22:55:19 +03:00
|
|
|
conf.Storage.GC = false
|
2023-04-07 19:49:24 +03:00
|
|
|
|
2022-03-04 09:37:06 +02:00
|
|
|
conf.Log.Output = logFile.Name()
|
2022-09-28 04:06:50 +03:00
|
|
|
trueValue := true
|
2022-03-04 09:37:06 +02:00
|
|
|
scrubConfig := &extconf.ScrubConfig{
|
2022-10-21 05:33:54 -07:00
|
|
|
BaseConfig: extconf.BaseConfig{Enable: &trueValue},
|
|
|
|
Interval: 2,
|
2022-03-04 09:37:06 +02:00
|
|
|
}
|
|
|
|
conf.Extensions = &extconf.ExtensionConfig{
|
|
|
|
Scrub: scrubConfig,
|
|
|
|
}
|
|
|
|
|
|
|
|
ctlr := api.NewController(conf)
|
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
srcStorageCtlr := ociutils.GetDefaultStoreController(dir, log.NewLogger("debug", ""))
|
2023-09-15 19:53:15 +03:00
|
|
|
image := CreateDefaultVulnerableImage()
|
2023-09-27 21:34:48 +03:00
|
|
|
err = WriteImageToFileSystem(image, repoName, "0.0.1", srcStorageCtlr)
|
2023-08-18 11:46:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2024-01-25 21:12:21 +02:00
|
|
|
layerDigest := image.Manifest.Layers[0].Digest
|
2022-03-04 09:37:06 +02:00
|
|
|
|
2024-01-25 21:12:21 +02:00
|
|
|
err = os.Remove(path.Join(dir, repoName, "blobs/sha256", layerDigest.Encoded()))
|
2022-03-04 09:37:06 +02:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2023-01-19 18:54:05 +02:00
|
|
|
cm := test.NewControllerManager(ctlr)
|
|
|
|
cm.StartAndWait(port)
|
|
|
|
defer cm.StopServer()
|
2022-03-04 09:37:06 +02:00
|
|
|
|
2023-12-11 20:00:34 +02:00
|
|
|
found, err := test.ReadLogFileAndSearchString(logFile.Name(), "blobs/manifest affected", 60*time.Second)
|
|
|
|
So(found, ShouldBeTrue)
|
2022-03-04 09:37:06 +02:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
})
|
|
|
|
|
2022-09-23 08:27:56 +03:00
|
|
|
Convey("Generator error - not enough permissions to access root directory", t, func(c C) {
|
2022-03-04 09:37:06 +02:00
|
|
|
port := test.GetFreePort()
|
|
|
|
|
2022-09-02 14:56:02 +02:00
|
|
|
logFile, err := os.CreateTemp("", "zot-log*.txt")
|
2022-03-04 09:37:06 +02:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
defer os.Remove(logFile.Name()) // clean up
|
|
|
|
|
|
|
|
conf := config.New()
|
|
|
|
conf.HTTP.Port = port
|
|
|
|
|
|
|
|
dir := t.TempDir()
|
|
|
|
|
|
|
|
conf.Storage.RootDirectory = dir
|
2023-04-07 19:49:24 +03:00
|
|
|
conf.Storage.Dedupe = false
|
2023-08-07 22:55:19 +03:00
|
|
|
conf.Storage.GC = false
|
2023-04-07 19:49:24 +03:00
|
|
|
|
2022-03-04 09:37:06 +02:00
|
|
|
conf.Log.Output = logFile.Name()
|
2022-09-28 04:06:50 +03:00
|
|
|
trueValue := true
|
2022-03-04 09:37:06 +02:00
|
|
|
scrubConfig := &extconf.ScrubConfig{
|
2022-10-21 05:33:54 -07:00
|
|
|
BaseConfig: extconf.BaseConfig{Enable: &trueValue},
|
|
|
|
Interval: 2,
|
2022-03-04 09:37:06 +02:00
|
|
|
}
|
|
|
|
conf.Extensions = &extconf.ExtensionConfig{
|
|
|
|
Scrub: scrubConfig,
|
|
|
|
}
|
|
|
|
|
|
|
|
ctlr := api.NewController(conf)
|
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
srcStorageCtlr := ociutils.GetDefaultStoreController(dir, log.NewLogger("debug", ""))
|
2023-09-15 19:53:15 +03:00
|
|
|
image := CreateDefaultVulnerableImage()
|
2023-08-18 11:46:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
err = WriteImageToFileSystem(image, repoName, "0.0.1", srcStorageCtlr)
|
2023-08-18 11:46:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
2022-03-04 09:37:06 +02:00
|
|
|
|
|
|
|
So(os.Chmod(path.Join(dir, repoName), 0o000), ShouldBeNil)
|
|
|
|
|
2023-01-19 18:54:05 +02:00
|
|
|
cm := test.NewControllerManager(ctlr)
|
|
|
|
cm.StartAndWait(port)
|
|
|
|
defer cm.StopServer()
|
2022-03-04 09:37:06 +02:00
|
|
|
|
2023-12-11 20:00:34 +02:00
|
|
|
found, err := test.ReadLogFileAndSearchString(logFile.Name(), "failed to execute generator", 60*time.Second)
|
|
|
|
So(found, ShouldBeTrue)
|
2022-03-04 09:37:06 +02:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
So(os.Chmod(path.Join(dir, repoName), 0o755), ShouldBeNil)
|
|
|
|
})
|
|
|
|
}
|
2022-05-10 01:30:11 +03:00
|
|
|
|
|
|
|
func TestRunScrubRepo(t *testing.T) {
|
|
|
|
Convey("Blobs integrity not affected", t, func(c C) {
|
2022-09-02 14:56:02 +02:00
|
|
|
logFile, err := os.CreateTemp("", "zot-log*.txt")
|
2022-05-10 01:30:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
defer os.Remove(logFile.Name()) // clean up
|
|
|
|
|
2022-06-24 16:08:47 +03:00
|
|
|
conf := config.New()
|
|
|
|
conf.Extensions = &extconf.ExtensionConfig{}
|
|
|
|
conf.Extensions.Lint = &extconf.LintConfig{}
|
|
|
|
|
2022-05-10 01:30:11 +03:00
|
|
|
dir := t.TempDir()
|
|
|
|
log := log.NewLogger("debug", logFile.Name())
|
|
|
|
metrics := monitoring.NewMetricsServer(false, log)
|
2022-11-03 00:53:08 +02:00
|
|
|
cacheDriver, _ := storage.Create("boltdb", cache.BoltDBDriverParameters{
|
|
|
|
RootDir: dir,
|
|
|
|
Name: "cache",
|
|
|
|
UseRelPaths: true,
|
|
|
|
}, log)
|
2023-09-22 21:51:20 +03:00
|
|
|
imgStore := local.NewImageStore(dir, true,
|
2022-11-03 00:53:08 +02:00
|
|
|
true, log, metrics, nil, cacheDriver)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
srcStorageCtlr := ociutils.GetDefaultStoreController(dir, log)
|
2023-09-15 19:53:15 +03:00
|
|
|
image := CreateDefaultVulnerableImage()
|
2023-08-18 11:46:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
err = WriteImageToFileSystem(image, repoName, "0.0.1", srcStorageCtlr)
|
2023-08-18 11:46:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
2023-09-05 19:48:56 +03:00
|
|
|
err = scrub.RunScrubRepo(context.Background(), imgStore, repoName, log)
|
2022-09-23 08:27:56 +03:00
|
|
|
So(err, ShouldBeNil)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
|
|
|
data, err := os.ReadFile(logFile.Name())
|
|
|
|
So(err, ShouldBeNil)
|
2023-12-08 00:05:02 -08:00
|
|
|
So(string(data), ShouldContainSubstring, "blobs/manifest ok")
|
2022-05-10 01:30:11 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Blobs integrity affected", t, func(c C) {
|
2022-09-02 14:56:02 +02:00
|
|
|
logFile, err := os.CreateTemp("", "zot-log*.txt")
|
2022-05-10 01:30:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
defer os.Remove(logFile.Name()) // clean up
|
|
|
|
|
2022-06-24 16:08:47 +03:00
|
|
|
conf := config.New()
|
|
|
|
|
|
|
|
conf.Extensions = &extconf.ExtensionConfig{}
|
|
|
|
conf.Extensions.Lint = &extconf.LintConfig{}
|
|
|
|
|
2022-05-10 01:30:11 +03:00
|
|
|
dir := t.TempDir()
|
|
|
|
log := log.NewLogger("debug", logFile.Name())
|
|
|
|
metrics := monitoring.NewMetricsServer(false, log)
|
2022-11-03 00:53:08 +02:00
|
|
|
cacheDriver, _ := storage.Create("boltdb", cache.BoltDBDriverParameters{
|
|
|
|
RootDir: dir,
|
|
|
|
Name: "cache",
|
|
|
|
UseRelPaths: true,
|
|
|
|
}, log)
|
2023-09-22 21:51:20 +03:00
|
|
|
imgStore := local.NewImageStore(dir, true,
|
2022-11-03 00:53:08 +02:00
|
|
|
true, log, metrics, nil, cacheDriver)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
srcStorageCtlr := ociutils.GetDefaultStoreController(dir, log)
|
2023-09-15 19:53:15 +03:00
|
|
|
image := CreateDefaultVulnerableImage()
|
2023-08-18 11:46:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
err = WriteImageToFileSystem(image, repoName, "0.0.1", srcStorageCtlr)
|
2023-08-18 11:46:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
2024-01-25 21:12:21 +02:00
|
|
|
layerDigest := image.Manifest.Layers[0].Digest
|
2022-05-10 01:30:11 +03:00
|
|
|
|
2024-01-25 21:12:21 +02:00
|
|
|
err = os.Remove(path.Join(dir, repoName, "blobs/sha256", layerDigest.Encoded()))
|
2022-05-10 01:30:11 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2023-09-05 19:48:56 +03:00
|
|
|
err = scrub.RunScrubRepo(context.Background(), imgStore, repoName, log)
|
2022-09-23 08:27:56 +03:00
|
|
|
So(err, ShouldBeNil)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
|
|
|
data, err := os.ReadFile(logFile.Name())
|
|
|
|
So(err, ShouldBeNil)
|
2023-12-08 00:05:02 -08:00
|
|
|
So(string(data), ShouldContainSubstring, "blobs/manifest affected")
|
2022-05-10 01:30:11 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
Convey("CheckRepo error - not enough permissions to access root directory", t, func(c C) {
|
2022-09-02 14:56:02 +02:00
|
|
|
logFile, err := os.CreateTemp("", "zot-log*.txt")
|
2022-05-10 01:30:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
defer os.Remove(logFile.Name()) // clean up
|
|
|
|
|
2022-06-24 16:08:47 +03:00
|
|
|
conf := config.New()
|
|
|
|
conf.Extensions = &extconf.ExtensionConfig{}
|
|
|
|
conf.Extensions.Lint = &extconf.LintConfig{}
|
|
|
|
|
2022-05-10 01:30:11 +03:00
|
|
|
dir := t.TempDir()
|
|
|
|
log := log.NewLogger("debug", logFile.Name())
|
|
|
|
metrics := monitoring.NewMetricsServer(false, log)
|
2022-11-03 00:53:08 +02:00
|
|
|
cacheDriver, _ := storage.Create("boltdb", cache.BoltDBDriverParameters{
|
|
|
|
RootDir: dir,
|
|
|
|
Name: "cache",
|
|
|
|
UseRelPaths: true,
|
|
|
|
}, log)
|
2023-09-22 21:51:20 +03:00
|
|
|
imgStore := local.NewImageStore(dir, true, true, log, metrics, nil, cacheDriver)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
srcStorageCtlr := ociutils.GetDefaultStoreController(dir, log)
|
2023-09-15 19:53:15 +03:00
|
|
|
image := CreateDefaultVulnerableImage()
|
2023-08-18 11:46:11 +03:00
|
|
|
|
2023-09-27 21:34:48 +03:00
|
|
|
err = WriteImageToFileSystem(image, repoName, "0.0.1", srcStorageCtlr)
|
2023-08-18 11:46:11 +03:00
|
|
|
So(err, ShouldBeNil)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
|
|
|
So(os.Chmod(path.Join(dir, repoName), 0o000), ShouldBeNil)
|
|
|
|
|
2023-09-05 19:48:56 +03:00
|
|
|
err = scrub.RunScrubRepo(context.Background(), imgStore, repoName, log)
|
2022-09-23 08:27:56 +03:00
|
|
|
So(err, ShouldNotBeNil)
|
2022-05-10 01:30:11 +03:00
|
|
|
|
|
|
|
data, err := os.ReadFile(logFile.Name())
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
So(string(data), ShouldContainSubstring,
|
2024-07-29 19:32:51 +02:00
|
|
|
"failed to run scrub for "+imgStore.RootDir())
|
2022-05-10 01:30:11 +03:00
|
|
|
So(os.Chmod(path.Join(dir, repoName), 0o755), ShouldBeNil)
|
|
|
|
})
|
|
|
|
}
|