fs: make display of default values of --min-age/--max-age be off - Fixes #2121

This commit is contained in:
Nick Craig-Wood 2018-03-12 20:52:42 +00:00
parent 4e90ad04d5
commit 0c9dc006c5
3 changed files with 49 additions and 20 deletions

View file

@ -92,12 +92,10 @@ type Opt struct {
MaxSize fs.SizeSuffix MaxSize fs.SizeSuffix
} }
const unusedAge = fs.Duration((1 << 63) - 1)
// DefaultOpt is the default config for the filter // DefaultOpt is the default config for the filter
var DefaultOpt = Opt{ var DefaultOpt = Opt{
MinAge: unusedAge, MinAge: fs.DurationOff,
MaxAge: unusedAge, MaxAge: fs.DurationOff,
MinSize: fs.SizeSuffix(-1), MinSize: fs.SizeSuffix(-1),
MaxSize: fs.SizeSuffix(-1), MaxSize: fs.SizeSuffix(-1),
} }
@ -126,11 +124,11 @@ func NewFilter(opt *Opt) (f *Filter, err error) {
} }
// Filter flags // Filter flags
if f.Opt.MinAge != unusedAge { if f.Opt.MinAge.IsSet() {
f.ModTimeTo = time.Now().Add(-time.Duration(f.Opt.MinAge)) f.ModTimeTo = time.Now().Add(-time.Duration(f.Opt.MinAge))
fs.Debugf(nil, "--min-age %v to %v", f.Opt.MinAge, f.ModTimeTo) fs.Debugf(nil, "--min-age %v to %v", f.Opt.MinAge, f.ModTimeTo)
} }
if f.Opt.MaxAge != unusedAge { if f.Opt.MaxAge.IsSet() {
f.ModTimeFrom = time.Now().Add(-time.Duration(f.Opt.MaxAge)) f.ModTimeFrom = time.Now().Add(-time.Duration(f.Opt.MaxAge))
if !f.ModTimeTo.IsZero() && f.ModTimeFrom.Before(f.ModTimeTo) { if !f.ModTimeTo.IsZero() && f.ModTimeFrom.Before(f.ModTimeTo) {
log.Fatal("filter: --min-age can't be larger than --max-age") log.Fatal("filter: --min-age can't be larger than --max-age")

View file

@ -9,11 +9,22 @@ import (
// Duration is a time.Duration with some more parsing options // Duration is a time.Duration with some more parsing options
type Duration time.Duration type Duration time.Duration
// DurationOff is the default value for flags which can be turned off
const DurationOff = Duration((1 << 63) - 1)
// Turn Duration into a string // Turn Duration into a string
func (d Duration) String() string { func (d Duration) String() string {
if d == DurationOff {
return "off"
}
return time.Duration(d).String() return time.Duration(d).String()
} }
// IsSet returns if the duration is != DurationOff
func (d Duration) IsSet() bool {
return d != DurationOff
}
// We use time conventions // We use time conventions
var ageSuffixes = []struct { var ageSuffixes = []struct {
Suffix string Suffix string
@ -36,6 +47,10 @@ var ageSuffixes = []struct {
func ParseDuration(age string) (time.Duration, error) { func ParseDuration(age string) (time.Duration, error) {
var period float64 var period float64
if age == "off" {
return time.Duration(DurationOff), nil
}
for _, ageSuffix := range ageSuffixes { for _, ageSuffix := range ageSuffixes {
if strings.HasSuffix(age, ageSuffix.Suffix) { if strings.HasSuffix(age, ageSuffix.Suffix) {
numberString := age[:len(age)-len(ageSuffix.Suffix)] numberString := age[:len(age)-len(ageSuffix.Suffix)]
@ -64,5 +79,5 @@ func (d *Duration) Set(s string) error {
// Type of the value // Type of the value
func (d Duration) Type() string { func (d Duration) Type() string {
return "time.Duration" return "duration"
} }

View file

@ -15,23 +15,24 @@ var _ pflag.Value = (*Duration)(nil)
func TestParseDuration(t *testing.T) { func TestParseDuration(t *testing.T) {
for _, test := range []struct { for _, test := range []struct {
in string in string
want float64 want time.Duration
err bool err bool
}{ }{
{"0", 0, false}, {"0", 0, false},
{"", 0, true}, {"", 0, true},
{"1ms", float64(time.Millisecond), false}, {"1ms", time.Millisecond, false},
{"1s", float64(time.Second), false}, {"1s", time.Second, false},
{"1m", float64(time.Minute), false}, {"1m", time.Minute, false},
{"1h", float64(time.Hour), false}, {"1h", time.Hour, false},
{"1d", float64(time.Hour) * 24, false}, {"1d", time.Hour * 24, false},
{"1w", float64(time.Hour) * 24 * 7, false}, {"1w", time.Hour * 24 * 7, false},
{"1M", float64(time.Hour) * 24 * 30, false}, {"1M", time.Hour * 24 * 30, false},
{"1y", float64(time.Hour) * 24 * 365, false}, {"1y", time.Hour * 24 * 365, false},
{"1.5y", float64(time.Hour) * 24 * 365 * 1.5, false}, {"1.5y", time.Hour * 24 * 365 * 3 / 2, false},
{"-1s", -float64(time.Second), false}, {"-1s", -time.Second, false},
{"1.s", float64(time.Second), false}, {"1.s", time.Second, false},
{"1x", 0, true}, {"1x", 0, true},
{"off", time.Duration(DurationOff), false},
} { } {
duration, err := ParseDuration(test.in) duration, err := ParseDuration(test.in)
if test.err { if test.err {
@ -39,6 +40,21 @@ func TestParseDuration(t *testing.T) {
} else { } else {
require.NoError(t, err) require.NoError(t, err)
} }
assert.Equal(t, test.want, float64(duration)) assert.Equal(t, test.want, duration)
}
}
func TestDurationString(t *testing.T) {
for _, test := range []struct {
in time.Duration
want string
}{
// {time.Duration(0), "0s"}, doesn't work on go1.6
{time.Second, "1s"},
{time.Minute, "1m0s"},
{time.Duration(DurationOff), "off"},
} {
got := Duration(test.in).String()
assert.Equal(t, test.want, got)
} }
} }