gauge_float64_test.go 1.22 KB
Newer Older
1 2 3 4
package metrics

import "testing"

5
func BenchmarkGaugeFloat64(b *testing.B) {
6 7 8 9 10 11 12 13 14
	g := NewGaugeFloat64()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		g.Update(float64(i))
	}
}

func TestGaugeFloat64(t *testing.T) {
	g := NewGaugeFloat64()
15 16
	g.Update(47.0)
	if v := g.Value(); 47.0 != v {
17 18 19 20 21 22
		t.Errorf("g.Value(): 47.0 != %v\n", v)
	}
}

func TestGaugeFloat64Snapshot(t *testing.T) {
	g := NewGaugeFloat64()
23
	g.Update(47.0)
24 25
	snapshot := g.Snapshot()
	g.Update(float64(0))
26
	if v := snapshot.Value(); 47.0 != v {
27 28 29 30 31 32
		t.Errorf("g.Value(): 47.0 != %v\n", v)
	}
}

func TestGetOrRegisterGaugeFloat64(t *testing.T) {
	r := NewRegistry()
33
	NewRegisteredGaugeFloat64("foo", r).Update(47.0)
34
	t.Logf("registry: %v", r)
35
	if g := GetOrRegisterGaugeFloat64("foo", r); 47.0 != g.Value() {
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
		t.Fatal(g)
	}
}

func TestFunctionalGaugeFloat64(t *testing.T) {
	var counter float64
	fg := NewFunctionalGaugeFloat64(func() float64 {
		counter++
		return counter
	})
	fg.Value()
	fg.Value()
	if counter != 2 {
		t.Error("counter != 2")
	}
}

func TestGetOrRegisterFunctionalGaugeFloat64(t *testing.T) {
	r := NewRegistry()
	NewRegisteredFunctionalGaugeFloat64("foo", r, func() float64 { return 47 })
56
	if g := GetOrRegisterGaugeFloat64("foo", r); g.Value() != 47 {
57 58 59
		t.Fatal(g)
	}
}