github.com/zjj1991/quorum@v0.0.0-20190524123704-ae4b0a1e1a19/metrics/gauge_float64_test.go (about) 1 package metrics 2 3 import "testing" 4 5 func BenchmarkGuageFloat64(b *testing.B) { 6 g := NewGaugeFloat64() 7 b.ResetTimer() 8 for i := 0; i < b.N; i++ { 9 g.Update(float64(i)) 10 } 11 } 12 13 func TestGaugeFloat64(t *testing.T) { 14 g := NewGaugeFloat64() 15 g.Update(float64(47.0)) 16 if v := g.Value(); float64(47.0) != v { 17 t.Errorf("g.Value(): 47.0 != %v\n", v) 18 } 19 } 20 21 func TestGaugeFloat64Snapshot(t *testing.T) { 22 g := NewGaugeFloat64() 23 g.Update(float64(47.0)) 24 snapshot := g.Snapshot() 25 g.Update(float64(0)) 26 if v := snapshot.Value(); float64(47.0) != v { 27 t.Errorf("g.Value(): 47.0 != %v\n", v) 28 } 29 } 30 31 func TestGetOrRegisterGaugeFloat64(t *testing.T) { 32 r := NewRegistry() 33 NewRegisteredGaugeFloat64("foo", r).Update(float64(47.0)) 34 t.Logf("registry: %v", r) 35 if g := GetOrRegisterGaugeFloat64("foo", r); float64(47.0) != g.Value() { 36 t.Fatal(g) 37 } 38 } 39 40 func TestFunctionalGaugeFloat64(t *testing.T) { 41 var counter float64 42 fg := NewFunctionalGaugeFloat64(func() float64 { 43 counter++ 44 return counter 45 }) 46 fg.Value() 47 fg.Value() 48 if counter != 2 { 49 t.Error("counter != 2") 50 } 51 } 52 53 func TestGetOrRegisterFunctionalGaugeFloat64(t *testing.T) { 54 r := NewRegistry() 55 NewRegisteredFunctionalGaugeFloat64("foo", r, func() float64 { return 47 }) 56 if g := GetOrRegisterGaugeFloat64("foo", r); 47 != g.Value() { 57 t.Fatal(g) 58 } 59 }