-
Notifications
You must be signed in to change notification settings - Fork 0
/
dynduration_test.go
80 lines (69 loc) · 2.67 KB
/
dynduration_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// Copyright 2015 Michal Witkowski. All Rights Reserved.
// See LICENSE for licensing terms.
package dflag
import (
"errors"
"flag"
"testing"
"time"
"fortio.org/assert"
)
func TestDynDuration_SetAndGet(t *testing.T) {
set := flag.NewFlagSet("foobar", flag.ContinueOnError)
dynFlag := DynDuration(set, "some_duration_1", 5*time.Second, "Use it or lose it")
assert.Equal(t, 5*time.Second, dynFlag.Get(), "value must be default after create")
err := set.Set("some_duration_1", "10h\n")
assert.NoError(t, err, "setting value must succeed")
assert.Equal(t, 10*time.Hour, dynFlag.Get(), "value must be set after update")
err = set.Set("some_duration_1", "not-a-duration")
assert.Error(t, err, "setting bogus value should fail")
}
func TestDynDuration_IsMarkedDynamic(t *testing.T) {
set := flag.NewFlagSet("foobar", flag.ContinueOnError)
DynDuration(set, "some_duration_1", 5*time.Minute, "Use it or lose it")
assert.True(t, IsFlagDynamic(set.Lookup("some_duration_1")))
}
func TestDynDuration_FiresValidators(t *testing.T) {
set := flag.NewFlagSet("foobar", flag.ContinueOnError)
validator := func(x time.Duration) error {
if x > 1*time.Hour {
return errors.New("too long")
}
return nil
}
DynDuration(set, "some_duration_1", 5*time.Second, "Use it or lose it").WithValidator(validator)
assert.NoError(t, set.Set("some_duration_1", "50m"), "no error from validator when in range")
assert.Error(t, set.Set("some_duration_1", "2h"), "error from validator when value out of range")
}
func TestDynDuration_FiresNotifier(t *testing.T) {
waitCh := make(chan bool, 1)
notifier := func(oldVal time.Duration, newVal time.Duration) {
assert.EqualValues(t, 5*time.Second, oldVal, "old value in notify must match previous value")
assert.EqualValues(t, 30*time.Second, newVal, "new value in notify must match set value")
waitCh <- true
}
set := flag.NewFlagSet("foobar", flag.ContinueOnError)
DynDuration(set, "some_duration_1", 5*time.Second, "Use it or lose it").WithNotifier(notifier)
set.Set("some_duration_1", "30s")
select {
case <-time.After(notifierTimeout):
assert.Fail(t, "failed to trigger notifier")
case <-waitCh:
}
}
func Benchmark_Duration_Dyn_Get(b *testing.B) {
set := flag.NewFlagSet("foobar", flag.ContinueOnError)
value := DynDuration(set, "some_duration_1", 5*time.Second, "Use it or lose it")
set.Set("some_duration_1", "10s")
for i := 0; i < b.N; i++ {
value.Get().Nanoseconds()
}
}
func Benchmark_Duration_Normal_get(b *testing.B) {
set := flag.NewFlagSet("foobar", flag.ContinueOnError)
valPtr := set.Duration("some_duration_1", 5*time.Second, "Use it or lose it")
set.Set("some_duration_1", "10s")
for i := 0; i < b.N; i++ {
valPtr.Nanoseconds()
}
}