2015-09-10 18:35:12 +00:00
|
|
|
|
package opentsdb
|
|
|
|
|
|
|
|
|
|
import (
|
2016-07-18 19:01:36 +00:00
|
|
|
|
"fmt"
|
|
|
|
|
"net"
|
|
|
|
|
"net/http"
|
|
|
|
|
"net/http/httptest"
|
|
|
|
|
"net/url"
|
2015-09-10 18:35:12 +00:00
|
|
|
|
"reflect"
|
2016-07-18 19:01:36 +00:00
|
|
|
|
"strconv"
|
2015-09-10 18:35:12 +00:00
|
|
|
|
"testing"
|
2016-07-18 19:01:36 +00:00
|
|
|
|
|
2017-09-14 00:30:52 +00:00
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
|
2016-07-18 19:01:36 +00:00
|
|
|
|
"github.com/influxdata/telegraf"
|
|
|
|
|
"github.com/influxdata/telegraf/testutil"
|
2015-09-10 18:35:12 +00:00
|
|
|
|
)
|
|
|
|
|
|
2016-07-18 19:01:36 +00:00
|
|
|
|
func TestCleanTags(t *testing.T) {
|
2015-09-10 18:35:12 +00:00
|
|
|
|
var tagtests = []struct {
|
|
|
|
|
ptIn map[string]string
|
2016-07-18 19:01:36 +00:00
|
|
|
|
outTags map[string]string
|
2015-09-10 18:35:12 +00:00
|
|
|
|
}{
|
|
|
|
|
{
|
2015-10-16 22:13:32 +00:00
|
|
|
|
map[string]string{"one": "two", "three": "four"},
|
2016-07-18 19:01:36 +00:00
|
|
|
|
map[string]string{"one": "two", "three": "four"},
|
2015-09-10 18:35:12 +00:00
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
map[string]string{"aaa": "bbb"},
|
2016-07-18 19:01:36 +00:00
|
|
|
|
map[string]string{"aaa": "bbb"},
|
2015-09-10 18:35:12 +00:00
|
|
|
|
},
|
|
|
|
|
{
|
2017-09-14 00:30:52 +00:00
|
|
|
|
map[string]string{"Sp%ci@l Chars[": "g$t repl#ce)d"},
|
|
|
|
|
map[string]string{"Sp-ci-l_Chars_": "g-t_repl-ce_d"},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
map[string]string{"μnicodε_letters": "okαy"},
|
|
|
|
|
map[string]string{"μnicodε_letters": "okαy"},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
map[string]string{"n☺": "emojies☠"},
|
|
|
|
|
map[string]string{"n_": "emojies_"},
|
2015-09-10 18:35:12 +00:00
|
|
|
|
},
|
2016-04-28 23:00:06 +00:00
|
|
|
|
{
|
2016-07-18 19:01:36 +00:00
|
|
|
|
map[string]string{},
|
|
|
|
|
map[string]string{},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tagtests {
|
|
|
|
|
tags := cleanTags(tt.ptIn)
|
|
|
|
|
if !reflect.DeepEqual(tags, tt.outTags) {
|
|
|
|
|
t.Errorf("\nexpected %+v\ngot %+v\n", tt.outTags, tags)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestBuildTagsTelnet(t *testing.T) {
|
|
|
|
|
var tagtests = []struct {
|
|
|
|
|
ptIn map[string]string
|
|
|
|
|
outTags string
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
map[string]string{"one": "two", "three": "four"},
|
|
|
|
|
"one=two three=four",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
map[string]string{"aaa": "bbb"},
|
|
|
|
|
"aaa=bbb",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
map[string]string{"one": "two", "aaa": "bbb"},
|
|
|
|
|
"aaa=bbb one=two",
|
2016-04-28 23:00:06 +00:00
|
|
|
|
},
|
2015-09-10 18:35:12 +00:00
|
|
|
|
{
|
|
|
|
|
map[string]string{},
|
2016-07-18 19:01:36 +00:00
|
|
|
|
"",
|
2015-09-10 18:35:12 +00:00
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, tt := range tagtests {
|
2016-07-18 19:01:36 +00:00
|
|
|
|
tags := ToLineFormat(tt.ptIn)
|
2015-09-10 18:35:12 +00:00
|
|
|
|
if !reflect.DeepEqual(tags, tt.outTags) {
|
|
|
|
|
t.Errorf("\nexpected %+v\ngot %+v\n", tt.outTags, tags)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-10-16 22:13:32 +00:00
|
|
|
|
|
2017-09-14 00:30:52 +00:00
|
|
|
|
func TestSanitize(t *testing.T) {
|
|
|
|
|
tests := []struct {
|
|
|
|
|
name string
|
|
|
|
|
value string
|
|
|
|
|
expected string
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Ascii letters and numbers allowed",
|
|
|
|
|
value: "ascii 123",
|
|
|
|
|
expected: "ascii_123",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Allowed punct",
|
|
|
|
|
value: "-_./",
|
|
|
|
|
expected: "-_./",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Special conversions to hyphen",
|
|
|
|
|
value: "@*%#$!",
|
|
|
|
|
expected: "-----_",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Unicode Letters allowed",
|
|
|
|
|
value: "μnicodε_letters",
|
|
|
|
|
expected: "μnicodε_letters",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Other Unicode not allowed",
|
|
|
|
|
value: "“☢”",
|
|
|
|
|
expected: "___",
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
|
actual := sanitize(tt.value)
|
|
|
|
|
require.Equal(t, tt.expected, actual)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-18 19:01:36 +00:00
|
|
|
|
func BenchmarkHttpSend(b *testing.B) {
|
|
|
|
|
const BatchSize = 50
|
|
|
|
|
const MetricsCount = 4 * BatchSize
|
|
|
|
|
metrics := make([]telegraf.Metric, MetricsCount)
|
|
|
|
|
for i := 0; i < MetricsCount; i++ {
|
|
|
|
|
metrics[i] = testutil.TestMetric(1.0)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
w.Header().Set("Content-Type", "application/json")
|
|
|
|
|
fmt.Fprintln(w, "{}")
|
|
|
|
|
}))
|
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
|
|
u, err := url.Parse(ts.URL)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, p, _ := net.SplitHostPort(u.Host)
|
|
|
|
|
|
|
|
|
|
port, err := strconv.Atoi(p)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
o := &OpenTSDB{
|
|
|
|
|
Host: ts.URL,
|
|
|
|
|
Port: port,
|
|
|
|
|
Prefix: "",
|
|
|
|
|
HttpBatchSize: BatchSize,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
b.ResetTimer()
|
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
|
o.Write(metrics)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-06-07 09:13:14 +00:00
|
|
|
|
// func TestWrite(t *testing.T) {
|
|
|
|
|
// if testing.Short() {
|
|
|
|
|
// t.Skip("Skipping integration test in short mode")
|
|
|
|
|
// }
|
2015-09-11 20:24:53 +00:00
|
|
|
|
|
2016-06-07 09:13:14 +00:00
|
|
|
|
// o := &OpenTSDB{
|
|
|
|
|
// Host: testutil.GetLocalHost(),
|
|
|
|
|
// Port: 4242,
|
|
|
|
|
// Prefix: "prefix.test.",
|
|
|
|
|
// }
|
2015-09-11 20:24:53 +00:00
|
|
|
|
|
2016-06-07 09:13:14 +00:00
|
|
|
|
// // Verify that we can connect to the OpenTSDB instance
|
|
|
|
|
// err := o.Connect()
|
|
|
|
|
// require.NoError(t, err)
|
2015-09-11 20:24:53 +00:00
|
|
|
|
|
2016-06-07 09:13:14 +00:00
|
|
|
|
// // Verify that we can successfully write data to OpenTSDB
|
|
|
|
|
// err = o.Write(testutil.MockMetrics())
|
|
|
|
|
// require.NoError(t, err)
|
2015-09-14 10:28:10 +00:00
|
|
|
|
|
2016-06-07 09:13:14 +00:00
|
|
|
|
// // Verify postive and negative test cases of writing data
|
|
|
|
|
// metrics := testutil.MockMetrics()
|
|
|
|
|
// metrics = append(metrics, testutil.TestMetric(float64(1.0),
|
|
|
|
|
// "justametric.float"))
|
|
|
|
|
// metrics = append(metrics, testutil.TestMetric(int64(123456789),
|
|
|
|
|
// "justametric.int"))
|
|
|
|
|
// metrics = append(metrics, testutil.TestMetric(uint64(123456789012345),
|
|
|
|
|
// "justametric.uint"))
|
|
|
|
|
// metrics = append(metrics, testutil.TestMetric("Lorem Ipsum",
|
|
|
|
|
// "justametric.string"))
|
|
|
|
|
// metrics = append(metrics, testutil.TestMetric(float64(42.0),
|
|
|
|
|
// "justametric.anotherfloat"))
|
|
|
|
|
// metrics = append(metrics, testutil.TestMetric(float64(42.0),
|
|
|
|
|
// "metric w/ specialchars"))
|
2015-10-16 22:13:32 +00:00
|
|
|
|
|
2016-06-07 09:13:14 +00:00
|
|
|
|
// err = o.Write(metrics)
|
|
|
|
|
// require.NoError(t, err)
|
|
|
|
|
// }
|