2016-02-10 22:50:07 +00:00
|
|
|
package graphite
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"sort"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
"github.com/influxdata/telegraf"
|
|
|
|
)
|
|
|
|
|
2016-04-08 22:04:45 +00:00
|
|
|
var defaultTags = map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-04-08 22:04:45 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
|
|
|
|
const (
|
|
|
|
template1 = "tags.measurement.field"
|
|
|
|
template2 = "host.measurement.field"
|
|
|
|
template3 = "host.tags.field"
|
|
|
|
template4 = "host.tags.measurement"
|
|
|
|
// this template explicitly uses all tag keys, so "tags" should be empty
|
|
|
|
template5 = "host.datacenter.cpu.tags.measurement.field"
|
|
|
|
// this template has non-existent tag keys
|
|
|
|
template6 = "foo.host.cpu.bar.tags.measurement.field"
|
|
|
|
)
|
|
|
|
|
2016-02-10 22:50:07 +00:00
|
|
|
func TestGraphiteTags(t *testing.T) {
|
|
|
|
m1, _ := telegraf.NewMetric(
|
|
|
|
"mymeasurement",
|
|
|
|
map[string]string{"host": "192.168.0.1"},
|
|
|
|
map[string]interface{}{"value": float64(3.14)},
|
|
|
|
time.Date(2010, time.November, 10, 23, 0, 0, 0, time.UTC),
|
|
|
|
)
|
|
|
|
m2, _ := telegraf.NewMetric(
|
|
|
|
"mymeasurement",
|
|
|
|
map[string]string{"host": "192.168.0.1", "afoo": "first", "bfoo": "second"},
|
|
|
|
map[string]interface{}{"value": float64(3.14)},
|
|
|
|
time.Date(2010, time.November, 10, 23, 0, 0, 0, time.UTC),
|
|
|
|
)
|
|
|
|
m3, _ := telegraf.NewMetric(
|
|
|
|
"mymeasurement",
|
|
|
|
map[string]string{"afoo": "first", "bfoo": "second"},
|
|
|
|
map[string]interface{}{"value": float64(3.14)},
|
|
|
|
time.Date(2010, time.November, 10, 23, 0, 0, 0, time.UTC),
|
|
|
|
)
|
|
|
|
|
2016-04-08 22:04:45 +00:00
|
|
|
tags1 := buildTags(m1.Tags())
|
|
|
|
tags2 := buildTags(m2.Tags())
|
|
|
|
tags3 := buildTags(m3.Tags())
|
2016-02-10 22:50:07 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
assert.Equal(t, "1.0.168.192", tags1)
|
|
|
|
assert.Equal(t, "first.second.1.0.168.192", tags2)
|
2016-02-10 22:50:07 +00:00
|
|
|
assert.Equal(t, "first.second", tags3)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSerializeMetricNoHost(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
"usage_busy": float64(8.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{}
|
2016-02-10 22:50:07 +00:00
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
|
|
|
fmt.Sprintf("cpu0.us-west-2.cpu.usage_idle 91.5 %d", now.Unix()),
|
|
|
|
fmt.Sprintf("cpu0.us-west-2.cpu.usage_busy 8.5 %d", now.Unix()),
|
|
|
|
}
|
|
|
|
sort.Strings(mS)
|
|
|
|
sort.Strings(expS)
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSerializeMetricHost(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-02-10 22:50:07 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
"usage_busy": float64(8.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{}
|
2016-02-10 22:50:07 +00:00
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.cpu0.us-west-2.cpu.usage_idle 91.5 %d", now.Unix()),
|
|
|
|
fmt.Sprintf("local.localhost.cpu0.us-west-2.cpu.usage_busy 8.5 %d", now.Unix()),
|
2016-02-10 22:50:07 +00:00
|
|
|
}
|
|
|
|
sort.Strings(mS)
|
|
|
|
sort.Strings(expS)
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
2016-04-08 22:04:45 +00:00
|
|
|
// test that a field named "value" gets ignored.
|
|
|
|
func TestSerializeValueField(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-04-08 22:04:45 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"value": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{}
|
2016-04-08 22:04:45 +00:00
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.cpu0.us-west-2.cpu 91.5 %d", now.Unix()),
|
2016-04-08 22:04:45 +00:00
|
|
|
}
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
// test that a field named "value" gets ignored in middle of template.
|
|
|
|
func TestSerializeValueField2(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-04-08 22:04:45 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"value": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{
|
2016-04-08 22:04:45 +00:00
|
|
|
Template: "host.field.tags.measurement",
|
|
|
|
}
|
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.cpu0.us-west-2.cpu 91.5 %d", now.Unix()),
|
2016-04-08 22:04:45 +00:00
|
|
|
}
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
2016-08-17 15:20:32 +00:00
|
|
|
// test that fields with spaces get fixed.
|
|
|
|
func TestSerializeFieldWithSpaces(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-08-17 15:20:32 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
`field\ with\ spaces`: float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{
|
2016-08-17 15:20:32 +00:00
|
|
|
Template: "host.tags.measurement.field",
|
|
|
|
}
|
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.cpu0.us-west-2.cpu.field_with_spaces 91.5 %d", now.Unix()),
|
2016-08-17 15:20:32 +00:00
|
|
|
}
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
// test that tags with spaces get fixed.
|
|
|
|
func TestSerializeTagWithSpaces(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-08-17 15:20:32 +00:00
|
|
|
"cpu": `cpu\ 0`,
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
`field_with_spaces`: float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{
|
2016-08-17 15:20:32 +00:00
|
|
|
Template: "host.tags.measurement.field",
|
|
|
|
}
|
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.cpu_0.us-west-2.cpu.field_with_spaces 91.5 %d", now.Unix()),
|
2016-08-17 15:20:32 +00:00
|
|
|
}
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
2016-04-08 22:04:45 +00:00
|
|
|
// test that a field named "value" gets ignored at beginning of template.
|
|
|
|
func TestSerializeValueField3(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-04-08 22:04:45 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"value": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{
|
2016-04-08 22:04:45 +00:00
|
|
|
Template: "field.host.tags.measurement",
|
|
|
|
}
|
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.cpu0.us-west-2.cpu 91.5 %d", now.Unix()),
|
2016-04-08 22:04:45 +00:00
|
|
|
}
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
2016-08-17 15:20:32 +00:00
|
|
|
// test that a field named "value" gets ignored at beginning of template.
|
|
|
|
func TestSerializeValueField5(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-08-17 15:20:32 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"value": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{
|
2016-08-17 15:20:32 +00:00
|
|
|
Template: template5,
|
|
|
|
}
|
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("local.localhost.us-west-2.cpu0.cpu 91.5 %d", now.Unix()),
|
2016-08-17 15:20:32 +00:00
|
|
|
}
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
2016-02-10 22:50:07 +00:00
|
|
|
func TestSerializeMetricPrefix(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
2016-11-10 21:05:50 +00:00
|
|
|
"host": "localhost.local",
|
2016-02-10 22:50:07 +00:00
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
"usage_busy": float64(8.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
s := SerializerGraphite{Prefix: "prefix"}
|
2016-02-10 22:50:07 +00:00
|
|
|
mS, err := s.Serialize(m)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
expS := []string{
|
2016-11-10 21:05:50 +00:00
|
|
|
fmt.Sprintf("prefix.local.localhost.cpu0.us-west-2.cpu.usage_idle 91.5 %d", now.Unix()),
|
|
|
|
fmt.Sprintf("prefix.local.localhost.cpu0.us-west-2.cpu.usage_busy 8.5 %d", now.Unix()),
|
2016-02-10 22:50:07 +00:00
|
|
|
}
|
|
|
|
sort.Strings(mS)
|
|
|
|
sort.Strings(expS)
|
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
2016-02-26 20:06:56 +00:00
|
|
|
|
|
|
|
func TestSerializeBucketNameNoHost(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
tags := map[string]string{
|
|
|
|
"cpu": "cpu0",
|
|
|
|
"datacenter": "us-west-2",
|
|
|
|
}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", tags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), "", "")
|
2016-02-26 20:06:56 +00:00
|
|
|
|
2016-04-08 22:04:45 +00:00
|
|
|
expS := "cpu0.us-west-2.cpu.FIELDNAME"
|
2016-02-26 20:06:56 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSerializeBucketNameHost(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
2016-04-08 22:04:45 +00:00
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
2016-02-26 20:06:56 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), "", "")
|
2016-02-26 20:06:56 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "local.localhost.cpu0.us-west-2.cpu.FIELDNAME"
|
2016-02-26 20:06:56 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSerializeBucketNamePrefix(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
2016-04-08 22:04:45 +00:00
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
2016-02-26 20:06:56 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), "", "prefix")
|
2016-04-08 22:04:45 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "prefix.local.localhost.cpu0.us-west-2.cpu.FIELDNAME"
|
2016-04-08 22:04:45 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTemplate1(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), template1, "")
|
2016-04-08 22:04:45 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "cpu0.us-west-2.local.localhost.cpu.FIELDNAME"
|
2016-04-08 22:04:45 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTemplate2(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), template2, "")
|
2016-04-08 22:04:45 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "local.localhost.cpu.FIELDNAME"
|
2016-04-08 22:04:45 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTemplate3(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), template3, "")
|
2016-04-08 22:04:45 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "local.localhost.cpu0.us-west-2.FIELDNAME"
|
2016-04-08 22:04:45 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTemplate4(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), template4, "")
|
2016-04-08 22:04:45 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "local.localhost.cpu0.us-west-2.cpu"
|
2016-04-08 22:04:45 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTemplate6(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"usage_idle": float64(91.5),
|
|
|
|
}
|
|
|
|
m, err := telegraf.NewMetric("cpu", defaultTags, fields, now)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2016-07-12 23:08:03 +00:00
|
|
|
mS := SerializeBucketName(m.Name(), m.Tags(), template6, "")
|
2016-02-26 20:06:56 +00:00
|
|
|
|
2016-11-10 21:05:50 +00:00
|
|
|
expS := "local.localhost.cpu0.us-west-2.cpu.FIELDNAME"
|
2016-02-26 20:06:56 +00:00
|
|
|
assert.Equal(t, expS, mS)
|
|
|
|
}
|