From 3f6c8f5a2233ab0be5667154dac48028e2f1a640 Mon Sep 17 00:00:00 2001 From: Ian Fijolek Date: Wed, 19 Apr 2023 15:31:12 -0700 Subject: [PATCH] Breaking: Remove 'SecondsOrDuration' for check_interval Now requires an explicit duration unit. Eg. 30s --- alert_test.go | 8 -------- config.go | 38 +++++--------------------------------- config_test.go | 6 +++--- main.go | 2 +- monitor.go | 8 ++++---- monitor_test.go | 6 +++--- test/valid-config.yml | 2 +- 7 files changed, 17 insertions(+), 53 deletions(-) diff --git a/alert_test.go b/alert_test.go index ff15a5d..938ba82 100644 --- a/alert_test.go +++ b/alert_test.go @@ -70,14 +70,6 @@ func TestAlertSend(t *testing.T) { "Command shell with bad template", false, }, - { - Alert{Command: CommandOrShell{ShellCommand: "echo {alert_message}"}}, - AlertNotice{MonitorName: "test", FailureCount: 1}, - "test check has failed 1 times\n", - false, - "Command shell with legacy template", - true, - }, // Test default log alert down { *NewLogAlert(), diff --git a/config.go b/config.go index 64cf410..8c2ec4e 100644 --- a/config.go +++ b/config.go @@ -13,11 +13,11 @@ var errInvalidConfig = errors.New("Invalid configuration") // Config type is contains all provided user configuration type Config struct { - CheckInterval SecondsOrDuration `yaml:"check_interval"` - DefaultAlertAfter int16 `yaml:"default_alert_after"` - DefaultAlertEvery *int16 `yaml:"default_alert_every"` - DefaultAlertDown []string `yaml:"default_alert_down"` - DefaultAlertUp []string `yaml:"default_alert_up"` + CheckInterval time.Duration `yaml:"check_interval"` + DefaultAlertAfter int16 `yaml:"default_alert_after"` + DefaultAlertEvery *int16 `yaml:"default_alert_every"` + DefaultAlertDown []string `yaml:"default_alert_down"` + DefaultAlertUp []string `yaml:"default_alert_up"` Monitors []*Monitor Alerts map[string]*Alert } @@ -56,34 +56,6 @@ func (cos *CommandOrShell) UnmarshalYAML(unmarshal func(interface{}) error) erro return nil } -// SecondsOrDuration wraps a duration value for parsing a duration or seconds from YAML -// NOTE: This should be removed in favor of only parsing durations once compatibility is broken -type SecondsOrDuration struct { - value time.Duration -} - -// Value returns a duration value -func (sod SecondsOrDuration) Value() time.Duration { - return sod.value -} - -// UnmarshalYAML allows unmarshalling a duration value or seconds if an int was provided -func (sod *SecondsOrDuration) UnmarshalYAML(unmarshal func(interface{}) error) error { - var seconds int64 - err := unmarshal(&seconds) - - if err == nil { - sod.value = time.Second * time.Duration(seconds) - - return nil - } - - // Error indicates that we don't have an int - err = unmarshal(&sod.value) - - return err -} - // IsValid checks config validity and returns true if valid func (config Config) IsValid() (isValid bool) { isValid = true diff --git a/config_test.go b/config_test.go index 2a20bad..099038a 100644 --- a/config_test.go +++ b/config_test.go @@ -47,15 +47,15 @@ func TestIntervalParsing(t *testing.T) { oneMinute := time.Minute // validate top level interval seconds represented as an int - if config.CheckInterval.Value() != oneSecond { + if config.CheckInterval != oneSecond { t.Errorf("Incorrectly parsed int seconds. expected=%v actual=%v", oneSecond, config.CheckInterval) } - if config.Monitors[0].CheckInterval.Value() != tenSeconds { + if config.Monitors[0].CheckInterval != tenSeconds { t.Errorf("Incorrectly parsed seconds duration. expected=%v actual=%v", oneSecond, config.CheckInterval) } - if config.Monitors[1].CheckInterval.Value() != oneMinute { + if config.Monitors[1].CheckInterval != oneMinute { t.Errorf("Incorrectly parsed seconds duration. expected=%v actual=%v", oneSecond, config.CheckInterval) } diff --git a/main.go b/main.go index 794976c..6e5a187 100644 --- a/main.go +++ b/main.go @@ -158,6 +158,6 @@ func main() { err = checkMonitors(&config) slog.OnErrPanicf(err, "Error checking monitors") - time.Sleep(config.CheckInterval.Value()) + time.Sleep(config.CheckInterval) } } diff --git a/monitor.go b/monitor.go index d907c66..b05937d 100644 --- a/monitor.go +++ b/monitor.go @@ -11,9 +11,9 @@ import ( // Monitor represents a particular periodic check of a command type Monitor struct { //nolint:maligned // Config values - AlertAfter int16 `yaml:"alert_after"` - AlertEvery *int16 `yaml:"alert_every"` - CheckInterval SecondsOrDuration `yaml:"check_interval"` + AlertAfter int16 `yaml:"alert_after"` + AlertEvery *int16 `yaml:"alert_every"` + CheckInterval time.Duration `yaml:"check_interval"` Name string AlertDown []string `yaml:"alert_down"` AlertUp []string `yaml:"alert_up"` @@ -45,7 +45,7 @@ func (monitor Monitor) ShouldCheck() bool { sinceLastCheck := time.Since(monitor.lastCheck) - return sinceLastCheck >= monitor.CheckInterval.Value() + return sinceLastCheck >= monitor.CheckInterval } // Check will run the command configured by the Monitor and return a status diff --git a/monitor_test.go b/monitor_test.go index 9648d6b..14c4079 100644 --- a/monitor_test.go +++ b/monitor_test.go @@ -45,9 +45,9 @@ func TestMonitorShouldCheck(t *testing.T) { name string }{ {Monitor{}, true, "Empty"}, - {Monitor{lastCheck: timeNow, CheckInterval: SecondsOrDuration{time.Second * 15}}, false, "Just checked"}, - {Monitor{lastCheck: timeTenSecAgo, CheckInterval: SecondsOrDuration{time.Second * 15}}, false, "-10s"}, - {Monitor{lastCheck: timeTwentySecAgo, CheckInterval: SecondsOrDuration{time.Second * 15}}, true, "-20s"}, + {Monitor{lastCheck: timeNow, CheckInterval: time.Second * 15}, false, "Just checked"}, + {Monitor{lastCheck: timeTenSecAgo, CheckInterval: time.Second * 15}, false, "-10s"}, + {Monitor{lastCheck: timeTwentySecAgo, CheckInterval: time.Second * 15}, true, "-20s"}, } for _, c := range cases { diff --git a/test/valid-config.yml b/test/valid-config.yml index 3860e95..da0a264 100644 --- a/test/valid-config.yml +++ b/test/valid-config.yml @@ -1,5 +1,5 @@ --- -check_interval: 1 +check_interval: 1s monitors: - name: Command