telegraf/plugins/outputs/graphite/graphite_test.go

101 lines
2.5 KiB
Go
Raw Normal View History

2016-01-08 00:26:33 +00:00
package graphite
import (
"bufio"
"net"
"net/textproto"
"sync"
"testing"
"time"
"github.com/influxdata/telegraf"
"github.com/influxdata/telegraf/metric"
2016-01-08 00:26:33 +00:00
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestGraphiteError(t *testing.T) {
// Init plugin
g := Graphite{
Servers: []string{"127.0.0.1:2003", "127.0.0.1:12003"},
Prefix: "my.prefix",
}
// Init metrics
m1, _ := metric.New(
2016-01-08 00:26:33 +00:00
"mymeasurement",
map[string]string{"host": "192.168.0.1"},
map[string]interface{}{"mymeasurement": float64(3.14)},
time.Date(2010, time.November, 10, 23, 0, 0, 0, time.UTC),
)
// Prepare point list
var metrics []telegraf.Metric
metrics = append(metrics, m1)
2016-01-08 00:26:33 +00:00
// Error
err1 := g.Connect()
require.NoError(t, err1)
err2 := g.Write(metrics)
2016-01-08 00:26:33 +00:00
require.Error(t, err2)
assert.Equal(t, "Could not write to any Graphite server in cluster\n", err2.Error())
}
func TestGraphiteOK(t *testing.T) {
var wg sync.WaitGroup
// Start TCP server
wg.Add(1)
go TCPServer(t, &wg)
// Give the fake graphite TCP server some time to start:
time.Sleep(time.Millisecond * 100)
2016-01-08 00:26:33 +00:00
// Init plugin
g := Graphite{
Prefix: "my.prefix",
}
// Init metrics
m1, _ := metric.New(
2016-01-08 00:26:33 +00:00
"mymeasurement",
map[string]string{"host": "192.168.0.1"},
map[string]interface{}{"myfield": float64(3.14)},
2016-01-08 00:26:33 +00:00
time.Date(2010, time.November, 10, 23, 0, 0, 0, time.UTC),
)
m2, _ := metric.New(
2016-01-08 00:26:33 +00:00
"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),
)
m3, _ := metric.New(
2016-01-08 00:26:33 +00:00
"my_measurement",
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),
)
2016-01-08 00:26:33 +00:00
// Prepare point list
metrics := []telegraf.Metric{m1, m2, m3}
2016-01-08 00:26:33 +00:00
err1 := g.Connect()
require.NoError(t, err1)
// Send Data
err2 := g.Write(metrics)
2016-01-08 00:26:33 +00:00
require.NoError(t, err2)
2016-01-08 00:26:33 +00:00
// Waiting TCPserver
wg.Wait()
g.Close()
}
func TCPServer(t *testing.T, wg *sync.WaitGroup) {
tcpServer, _ := net.Listen("tcp", "127.0.0.1:2003")
defer wg.Done()
2016-01-08 00:26:33 +00:00
conn, _ := tcpServer.Accept()
reader := bufio.NewReader(conn)
tp := textproto.NewReader(reader)
data1, _ := tp.ReadLine()
assert.Equal(t, "my.prefix.192_168_0_1.mymeasurement.myfield 3.14 1289430000", data1)
2016-01-08 00:26:33 +00:00
data2, _ := tp.ReadLine()
assert.Equal(t, "my.prefix.192_168_0_1.mymeasurement 3.14 1289430000", data2)
2016-01-08 00:26:33 +00:00
data3, _ := tp.ReadLine()
assert.Equal(t, "my.prefix.192_168_0_1.my_measurement 3.14 1289430000", data3)
2016-01-08 00:26:33 +00:00
conn.Close()
}