mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-11-23 12:31:07 +01:00
05ac508fbf
The purpose of this change is to reduce confusion between using
`flag.Duration` and `flagutils.Duration`. The reason is that
`flagutils.Duration` was mistakenly used for cases that required `m`
support. See
ab0d31a7b0
The change in name should clearly indicate the purpose of this data
type.
### Describe Your Changes
Please provide a brief description of the changes you made. Be as
specific as possible to help others understand the purpose and impact of
your modifications.
### Checklist
The following checks are **mandatory**:
- [ ] My change adheres [VictoriaMetrics contributing
guidelines](https://docs.victoriametrics.com/contributing/).
Signed-off-by: hagen1778 <roman@victoriametrics.com>
84 lines
1.8 KiB
Go
84 lines
1.8 KiB
Go
package flagutil
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestDurationSetFailure(t *testing.T) {
|
|
f := func(value string) {
|
|
t.Helper()
|
|
var d RetentionDuration
|
|
if err := d.Set(value); err == nil {
|
|
t.Fatalf("expecting non-nil error in d.Set(%q)", value)
|
|
}
|
|
}
|
|
f("foobar")
|
|
f("5foobar")
|
|
f("ah")
|
|
f("134xd")
|
|
f("2.43sdfw")
|
|
|
|
// Too big value in months
|
|
f("12345")
|
|
|
|
// Too big duration
|
|
f("999y")
|
|
f("100000000000y")
|
|
|
|
// Negative duration
|
|
f("-1")
|
|
f("-34h")
|
|
|
|
// RetentionDuration in minutes is confused with duration in months
|
|
f("1m")
|
|
}
|
|
|
|
func TestDurationSetSuccess(t *testing.T) {
|
|
f := func(value string, expectedMsecs int64) {
|
|
t.Helper()
|
|
var d RetentionDuration
|
|
if err := d.Set(value); err != nil {
|
|
t.Fatalf("unexpected error in d.Set(%q): %s", value, err)
|
|
}
|
|
if d.Milliseconds() != expectedMsecs {
|
|
t.Fatalf("unexpected result; got %d; want %d", d.Milliseconds(), expectedMsecs)
|
|
}
|
|
valueString := d.String()
|
|
valueExpected := strings.ToLower(value)
|
|
if valueString != valueExpected {
|
|
t.Fatalf("unexpected valueString; got %q; want %q", valueString, valueExpected)
|
|
}
|
|
}
|
|
f("", 0)
|
|
f("0", 0)
|
|
f("1", msecsPer31Days)
|
|
f("123.456", 123.456*msecsPer31Days)
|
|
f("1h", 3600*1000)
|
|
f("1.5d", 1.5*24*3600*1000)
|
|
f("2.3W", 2.3*7*24*3600*1000)
|
|
f("1w", 7*24*3600*1000)
|
|
f("0.25y", 0.25*365*24*3600*1000)
|
|
f("100y", 100*365*24*3600*1000)
|
|
}
|
|
|
|
func TestDurationDuration(t *testing.T) {
|
|
f := func(value string, expected time.Duration) {
|
|
t.Helper()
|
|
var d RetentionDuration
|
|
if err := d.Set(value); err != nil {
|
|
t.Fatalf("unexpected error in d.Set(%q): %s", value, err)
|
|
}
|
|
if d.Duration() != expected {
|
|
t.Fatalf("unexpected result; got %v; want %v", d.Duration().String(), expected.String())
|
|
}
|
|
}
|
|
f("0", 0)
|
|
f("1", 31*24*time.Hour)
|
|
f("1h", time.Hour)
|
|
f("1.5d", 1.5*24*time.Hour)
|
|
f("1w", 7*24*time.Hour)
|
|
f("0.25y", 0.25*365*24*time.Hour)
|
|
}
|