mirror of
https://github.com/project-zot/zot.git
synced 2024-12-30 22:34:13 -05:00
add enable/disable option for scrub extension (#827)
Signed-off-by: Andreea-Lupu <andreealupu1470@yahoo.com>
This commit is contained in:
parent
18d17f5d4c
commit
5ef023dbc1
8 changed files with 96 additions and 5 deletions
|
@ -46,6 +46,7 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"scrub": {
|
"scrub": {
|
||||||
|
"enable": true,
|
||||||
"interval": "24h"
|
"interval": "24h"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
},
|
},
|
||||||
"extensions": {
|
"extensions": {
|
||||||
"scrub": {
|
"scrub": {
|
||||||
|
"enable": true,
|
||||||
"interval": "24h"
|
"interval": "24h"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -413,7 +413,38 @@ func TestServeScrubExtension(t *testing.T) {
|
||||||
|
|
||||||
defer func() { os.Args = oldArgs }()
|
defer func() { os.Args = oldArgs }()
|
||||||
|
|
||||||
Convey("scrub enabled by scrub interval param set", t, func(c C) {
|
Convey("scrub implicitly enabled", t, func(c C) {
|
||||||
|
content := `{
|
||||||
|
"storage": {
|
||||||
|
"rootDirectory": "%s"
|
||||||
|
},
|
||||||
|
"http": {
|
||||||
|
"address": "127.0.0.1",
|
||||||
|
"port": "%s"
|
||||||
|
},
|
||||||
|
"log": {
|
||||||
|
"level": "debug",
|
||||||
|
"output": "%s"
|
||||||
|
},
|
||||||
|
"extensions": {
|
||||||
|
"scrub": {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}`
|
||||||
|
|
||||||
|
logPath, err := runCLIWithConfig(t.TempDir(), content)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
data, err := os.ReadFile(logPath)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
defer os.Remove(logPath) // clean up
|
||||||
|
dataStr := string(data)
|
||||||
|
So(dataStr, ShouldContainSubstring,
|
||||||
|
"\"Extensions\":{\"Search\":null,\"Sync\":null,\"Metrics\":null,\"Scrub\":{\"Enable\":true,\"Interval\":86400000000000},\"Lint\":null") //nolint:lll // gofumpt conflicts with lll
|
||||||
|
So(dataStr, ShouldNotContainSubstring,
|
||||||
|
"Scrub interval set to too-short interval < 2h, changing scrub duration to 2 hours and continuing.")
|
||||||
|
})
|
||||||
|
|
||||||
|
Convey("scrub implicitly enabled, but with scrub interval param set", t, func(c C) {
|
||||||
content := `{
|
content := `{
|
||||||
"storage": {
|
"storage": {
|
||||||
"rootDirectory": "%s"
|
"rootDirectory": "%s"
|
||||||
|
@ -441,12 +472,12 @@ func TestServeScrubExtension(t *testing.T) {
|
||||||
// Even if in config we specified scrub interval=1h, the minimum interval is 2h
|
// Even if in config we specified scrub interval=1h, the minimum interval is 2h
|
||||||
dataStr := string(data)
|
dataStr := string(data)
|
||||||
So(dataStr, ShouldContainSubstring,
|
So(dataStr, ShouldContainSubstring,
|
||||||
"\"Extensions\":{\"Search\":null,\"Sync\":null,\"Metrics\":null,\"Scrub\":{\"Interval\":3600000000000},\"Lint\":null") //nolint:lll // gofumpt conflicts with lll
|
"\"Extensions\":{\"Search\":null,\"Sync\":null,\"Metrics\":null,\"Scrub\":{\"Enable\":true,\"Interval\":3600000000000},\"Lint\":null") //nolint:lll // gofumpt conflicts with lll
|
||||||
So(dataStr, ShouldContainSubstring,
|
So(dataStr, ShouldContainSubstring,
|
||||||
"Scrub interval set to too-short interval < 2h, changing scrub duration to 2 hours and continuing.")
|
"Scrub interval set to too-short interval < 2h, changing scrub duration to 2 hours and continuing.")
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("scrub not enabled - scrub interval param not set", t, func(c C) {
|
Convey("scrub explicitly enabled, but without scrub interval param set", t, func(c C) {
|
||||||
content := `{
|
content := `{
|
||||||
"storage": {
|
"storage": {
|
||||||
"rootDirectory": "%s"
|
"rootDirectory": "%s"
|
||||||
|
@ -461,6 +492,7 @@ func TestServeScrubExtension(t *testing.T) {
|
||||||
},
|
},
|
||||||
"extensions": {
|
"extensions": {
|
||||||
"scrub": {
|
"scrub": {
|
||||||
|
"enable": true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}`
|
}`
|
||||||
|
@ -472,7 +504,39 @@ func TestServeScrubExtension(t *testing.T) {
|
||||||
defer os.Remove(logPath) // clean up
|
defer os.Remove(logPath) // clean up
|
||||||
dataStr := string(data)
|
dataStr := string(data)
|
||||||
So(dataStr, ShouldContainSubstring,
|
So(dataStr, ShouldContainSubstring,
|
||||||
"\"Extensions\":{\"Search\":null,\"Sync\":null,\"Metrics\":null,\"Scrub\":null,\"Lint\":null}")
|
"\"Extensions\":{\"Search\":null,\"Sync\":null,\"Metrics\":null,\"Scrub\":{\"Enable\":true,\"Interval\":86400000000000},\"Lint\":null") //nolint:lll // gofumpt conflicts with lll
|
||||||
|
So(dataStr, ShouldNotContainSubstring,
|
||||||
|
"Scrub interval set to too-short interval < 2h, changing scrub duration to 2 hours and continuing.")
|
||||||
|
})
|
||||||
|
|
||||||
|
Convey("scrub explicitly disabled", t, func(c C) {
|
||||||
|
content := `{
|
||||||
|
"storage": {
|
||||||
|
"rootDirectory": "%s"
|
||||||
|
},
|
||||||
|
"http": {
|
||||||
|
"address": "127.0.0.1",
|
||||||
|
"port": "%s"
|
||||||
|
},
|
||||||
|
"log": {
|
||||||
|
"level": "debug",
|
||||||
|
"output": "%s"
|
||||||
|
},
|
||||||
|
"extensions": {
|
||||||
|
"scrub": {
|
||||||
|
"enable": false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}`
|
||||||
|
|
||||||
|
logPath, err := runCLIWithConfig(t.TempDir(), content)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
data, err := os.ReadFile(logPath)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
defer os.Remove(logPath) // clean up
|
||||||
|
dataStr := string(data)
|
||||||
|
So(dataStr, ShouldContainSubstring,
|
||||||
|
"\"Extensions\":{\"Search\":null,\"Sync\":null,\"Metrics\":null,\"Scrub\":{\"Enable\":false,\"Interval\":86400000000000},\"Lint\":null}") //nolint:lll // gofumpt conflicts with lll
|
||||||
So(dataStr, ShouldContainSubstring, "Scrub config not provided, skipping scrub")
|
So(dataStr, ShouldContainSubstring, "Scrub config not provided, skipping scrub")
|
||||||
So(dataStr, ShouldNotContainSubstring,
|
So(dataStr, ShouldNotContainSubstring,
|
||||||
"Scrub interval set to too-short interval < 2h, changing scrub duration to 2 hours and continuing.")
|
"Scrub interval set to too-short interval < 2h, changing scrub duration to 2 hours and continuing.")
|
||||||
|
|
|
@ -344,6 +344,13 @@ func applyDefaultValues(config *config.Config, viperInstance *viper.Viper) {
|
||||||
// Note: In case search is not empty the config.Extensions will not be nil and we will not reach here
|
// Note: In case search is not empty the config.Extensions will not be nil and we will not reach here
|
||||||
config.Extensions.Search = &extconf.SearchConfig{}
|
config.Extensions.Search = &extconf.SearchConfig{}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_, ok = extMap["scrub"]
|
||||||
|
if ok {
|
||||||
|
// we found a config like `"extensions": {"scrub:": {}}`
|
||||||
|
// Note: In case scrub is not empty the config.Extensions will not be nil and we will not reach here
|
||||||
|
config.Extensions.Scrub = &extconf.ScrubConfig{}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if config.Extensions != nil {
|
if config.Extensions != nil {
|
||||||
|
@ -378,6 +385,16 @@ func applyDefaultValues(config *config.Config, viperInstance *viper.Viper) {
|
||||||
config.Extensions.Metrics.Prometheus = &extconf.PrometheusConfig{Path: constants.DefaultMetricsExtensionRoute}
|
config.Extensions.Metrics.Prometheus = &extconf.PrometheusConfig{Path: constants.DefaultMetricsExtensionRoute}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if config.Extensions.Scrub != nil {
|
||||||
|
if config.Extensions.Scrub.Enable == nil {
|
||||||
|
config.Extensions.Scrub.Enable = &defaultVal
|
||||||
|
}
|
||||||
|
|
||||||
|
if config.Extensions.Scrub.Interval == 0 {
|
||||||
|
config.Extensions.Scrub.Interval = 24 * time.Hour // nolint: gomnd
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if !config.Storage.GC && viperInstance.Get("storage::gcdelay") == nil {
|
if !config.Storage.GC && viperInstance.Get("storage::gcdelay") == nil {
|
||||||
|
|
|
@ -39,5 +39,6 @@ type PrometheusConfig struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type ScrubConfig struct {
|
type ScrubConfig struct {
|
||||||
|
Enable *bool
|
||||||
Interval time.Duration
|
Interval time.Duration
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ func EnableScrubExtension(config *config.Config, log log.Logger, storeController
|
||||||
sch *scheduler.Scheduler,
|
sch *scheduler.Scheduler,
|
||||||
) {
|
) {
|
||||||
if config.Extensions.Scrub != nil &&
|
if config.Extensions.Scrub != nil &&
|
||||||
config.Extensions.Scrub.Interval != 0 {
|
*config.Extensions.Scrub.Enable {
|
||||||
minScrubInterval, _ := time.ParseDuration("2h")
|
minScrubInterval, _ := time.ParseDuration("2h")
|
||||||
|
|
||||||
if config.Extensions.Scrub.Interval < minScrubInterval {
|
if config.Extensions.Scrub.Interval < minScrubInterval {
|
||||||
|
|
|
@ -48,7 +48,9 @@ func TestScrubExtension(t *testing.T) {
|
||||||
substore := config.StorageConfig{RootDirectory: subdir}
|
substore := config.StorageConfig{RootDirectory: subdir}
|
||||||
conf.Storage.SubPaths = map[string]config.StorageConfig{"/a": substore}
|
conf.Storage.SubPaths = map[string]config.StorageConfig{"/a": substore}
|
||||||
conf.Log.Output = logFile.Name()
|
conf.Log.Output = logFile.Name()
|
||||||
|
trueValue := true
|
||||||
scrubConfig := &extconf.ScrubConfig{
|
scrubConfig := &extconf.ScrubConfig{
|
||||||
|
Enable: &trueValue,
|
||||||
Interval: 2,
|
Interval: 2,
|
||||||
}
|
}
|
||||||
conf.Extensions = &extconf.ExtensionConfig{
|
conf.Extensions = &extconf.ExtensionConfig{
|
||||||
|
@ -106,7 +108,9 @@ func TestScrubExtension(t *testing.T) {
|
||||||
|
|
||||||
conf.Storage.RootDirectory = dir
|
conf.Storage.RootDirectory = dir
|
||||||
conf.Log.Output = logFile.Name()
|
conf.Log.Output = logFile.Name()
|
||||||
|
trueValue := true
|
||||||
scrubConfig := &extconf.ScrubConfig{
|
scrubConfig := &extconf.ScrubConfig{
|
||||||
|
Enable: &trueValue,
|
||||||
Interval: 2,
|
Interval: 2,
|
||||||
}
|
}
|
||||||
conf.Extensions = &extconf.ExtensionConfig{
|
conf.Extensions = &extconf.ExtensionConfig{
|
||||||
|
@ -171,7 +175,9 @@ func TestScrubExtension(t *testing.T) {
|
||||||
|
|
||||||
conf.Storage.RootDirectory = dir
|
conf.Storage.RootDirectory = dir
|
||||||
conf.Log.Output = logFile.Name()
|
conf.Log.Output = logFile.Name()
|
||||||
|
trueValue := true
|
||||||
scrubConfig := &extconf.ScrubConfig{
|
scrubConfig := &extconf.ScrubConfig{
|
||||||
|
Enable: &trueValue,
|
||||||
Interval: 2,
|
Interval: 2,
|
||||||
}
|
}
|
||||||
conf.Extensions = &extconf.ExtensionConfig{
|
conf.Extensions = &extconf.ExtensionConfig{
|
||||||
|
|
|
@ -35,6 +35,7 @@ function setup() {
|
||||||
},
|
},
|
||||||
"extensions": {
|
"extensions": {
|
||||||
"scrub": {
|
"scrub": {
|
||||||
|
"enable": true,
|
||||||
"interval": "2h"
|
"interval": "2h"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue