2018-11-15 12:54:45 +00:00
|
|
|
package metric
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/p2p"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/prometheus"
|
|
|
|
)
|
|
|
|
|
|
|
|
const addr = "127.0.0.1:8989"
|
|
|
|
|
2019-02-22 15:11:26 +00:00
|
|
|
func TestMessageMetrics_OK(t *testing.T) {
|
2018-12-30 21:20:43 +00:00
|
|
|
service := prometheus.NewPrometheusService(addr, nil)
|
2018-11-15 12:54:45 +00:00
|
|
|
go service.Start()
|
|
|
|
defer service.Stop()
|
|
|
|
|
|
|
|
adapter := New()
|
|
|
|
if adapter == nil {
|
|
|
|
t.Error("Expected metric adapter")
|
|
|
|
}
|
2018-12-22 20:30:59 +00:00
|
|
|
data := &pb.Attestation{
|
2019-02-06 16:20:38 +00:00
|
|
|
AggregationBitfield: []byte{99},
|
2018-12-22 20:30:59 +00:00
|
|
|
Data: &pb.AttestationData{
|
|
|
|
Slot: 0,
|
|
|
|
},
|
2018-11-15 12:54:45 +00:00
|
|
|
}
|
|
|
|
h := adapter(func(p2p.Message) { time.Sleep(10 * time.Millisecond) })
|
|
|
|
h(p2p.Message{Ctx: context.Background(), Data: data})
|
|
|
|
h = adapter(func(p2p.Message) { time.Sleep(100 * time.Microsecond) })
|
|
|
|
h(p2p.Message{Ctx: context.Background(), Data: data})
|
|
|
|
|
|
|
|
metrics := getMetrics(t)
|
|
|
|
testMetricExists(t, metrics, fmt.Sprintf("p2p_message_sent_total{message=\"%T\"} 2", data))
|
|
|
|
testMetricExists(t, metrics, fmt.Sprintf("p2p_message_sent_latency_seconds_bucket{message=\"%T\",le=\"0.005\"} 1", data))
|
|
|
|
testMetricExists(t, metrics, fmt.Sprintf("p2p_message_sent_latency_seconds_bucket{message=\"%T\",le=\"0.01\"} 1", data))
|
|
|
|
}
|
|
|
|
|
|
|
|
func getMetrics(t *testing.T) []string {
|
|
|
|
resp, err := http.Get(fmt.Sprintf("http://%s/metrics", addr))
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
body, err := ioutil.ReadAll(resp.Body)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
return strings.Split(string(body), "\n")
|
|
|
|
}
|
|
|
|
|
|
|
|
func testMetricExists(t *testing.T, metrics []string, pattern string) string {
|
|
|
|
for _, line := range metrics {
|
|
|
|
if strings.HasPrefix(line, pattern) {
|
|
|
|
return line
|
|
|
|
}
|
|
|
|
}
|
2018-12-19 02:50:26 +00:00
|
|
|
t.Errorf("Pattern \"%s\" not found in metrics", pattern)
|
2018-11-15 12:54:45 +00:00
|
|
|
return ""
|
|
|
|
}
|