245 lines
5.2 KiB
Go
245 lines
5.2 KiB
Go
package http
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/influxdata/telegraf"
|
|
"github.com/influxdata/telegraf/metric"
|
|
"github.com/influxdata/telegraf/plugins/serializers/graphite"
|
|
"github.com/influxdata/telegraf/plugins/serializers/json"
|
|
"github.com/stretchr/testify/assert"
|
|
"io/ioutil"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
var (
|
|
cpuTags = map[string]string{
|
|
"host": "localhost",
|
|
"cpu": "cpu0",
|
|
"datacenter": "us-west-2",
|
|
}
|
|
|
|
cpuField = map[string]interface{}{
|
|
"usage_idle": float64(91.5),
|
|
}
|
|
|
|
memTags = map[string]string{
|
|
"host": "localhost",
|
|
"cpu": "mem",
|
|
"datacenter": "us-west-2",
|
|
}
|
|
|
|
memField = map[string]interface{}{
|
|
"used": float64(91.5),
|
|
}
|
|
|
|
count int
|
|
)
|
|
|
|
type TestOkHandler struct {
|
|
T *testing.T
|
|
Expected []string
|
|
}
|
|
|
|
// The handler gets a new variable each time it receives a request, so it fetches an expected string based on global variable.
|
|
func (h TestOkHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
|
actual, _ := ioutil.ReadAll(r.Body)
|
|
|
|
assert.Equal(h.T, h.Expected[count], string(actual), fmt.Sprintf("%d Expected fail!", count))
|
|
|
|
count++
|
|
|
|
fmt.Fprint(w, "ok")
|
|
}
|
|
|
|
type TestNotFoundHandler struct {
|
|
}
|
|
|
|
func (h TestNotFoundHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
|
http.NotFound(w, r)
|
|
}
|
|
|
|
func TestWriteAllInputMetric(t *testing.T) {
|
|
now := time.Now()
|
|
|
|
server := httptest.NewServer(&TestOkHandler{
|
|
T: t,
|
|
Expected: []string{
|
|
fmt.Sprintf("telegraf.cpu0.us-west-2.localhost.cpu.usage_idle 91.5 %d\ntelegraf.mem.us-west-2.localhost.mem.used 91.5 %d\n", now.Unix(), now.Unix()),
|
|
},
|
|
})
|
|
defer server.Close()
|
|
defer resetCount()
|
|
|
|
m1, _ := metric.New("cpu", cpuTags, cpuField, now)
|
|
m2, _ := metric.New("mem", memTags, memField, now)
|
|
metrics := []telegraf.Metric{m1, m2}
|
|
|
|
http := &Http{
|
|
URL: server.URL,
|
|
Headers: map[string]string{
|
|
"Content-Type": "plain/text",
|
|
},
|
|
}
|
|
|
|
http.SetSerializer(&graphite.GraphiteSerializer{
|
|
Prefix: "telegraf",
|
|
Template: "tags.measurement.field",
|
|
})
|
|
|
|
http.Connect()
|
|
err := http.Write(metrics)
|
|
|
|
assert.NoError(t, err)
|
|
}
|
|
|
|
func TestHttpWriteWithUnexpected404StatusCode(t *testing.T) {
|
|
now := time.Now()
|
|
|
|
server := httptest.NewServer(&TestNotFoundHandler{})
|
|
defer server.Close()
|
|
|
|
m, _ := metric.New("cpu", cpuTags, cpuField, now)
|
|
metrics := []telegraf.Metric{m}
|
|
|
|
http := &Http{
|
|
URL: server.URL,
|
|
Headers: map[string]string{
|
|
"Content-Type": "application/json",
|
|
},
|
|
}
|
|
|
|
http.SetSerializer(&graphite.GraphiteSerializer{
|
|
Prefix: "telegraf",
|
|
Template: "tags.measurement.field",
|
|
})
|
|
|
|
http.Connect()
|
|
err := http.Write(metrics)
|
|
|
|
assert.Error(t, err)
|
|
}
|
|
|
|
func TestHttpWriteWithExpected404StatusCode(t *testing.T) {
|
|
now := time.Now()
|
|
|
|
server := httptest.NewServer(&TestNotFoundHandler{})
|
|
defer server.Close()
|
|
|
|
m, _ := metric.New("cpu", cpuTags, cpuField, now)
|
|
metrics := []telegraf.Metric{m}
|
|
|
|
http := &Http{
|
|
URL: server.URL,
|
|
Headers: map[string]string{
|
|
"Content-Type": "application/json",
|
|
},
|
|
}
|
|
|
|
http.SetSerializer(&graphite.GraphiteSerializer{
|
|
Prefix: "telegraf",
|
|
Template: "tags.measurement.field",
|
|
})
|
|
|
|
http.Connect()
|
|
err := http.Write(metrics)
|
|
|
|
assert.Error(t, err)
|
|
}
|
|
|
|
func TestHttpWriteWithIncorrectServerPort(t *testing.T) {
|
|
now := time.Now()
|
|
|
|
m, _ := metric.New("cpu", cpuTags, cpuField, now)
|
|
metrics := []telegraf.Metric{m}
|
|
|
|
http := &Http{
|
|
URL: "http://127.0.0.1:56879/incorrect/url",
|
|
Headers: map[string]string{
|
|
"Content-Type": "application/json",
|
|
},
|
|
}
|
|
|
|
http.SetSerializer(&graphite.GraphiteSerializer{
|
|
Prefix: "telegraf",
|
|
Template: "tags.measurement.field",
|
|
})
|
|
|
|
http.Connect()
|
|
err := http.Write(metrics)
|
|
|
|
assert.Error(t, err)
|
|
}
|
|
|
|
func TestHttpWriteWithHttpSerializer(t *testing.T) {
|
|
now := time.Now()
|
|
|
|
server := httptest.NewServer(&TestOkHandler{
|
|
T: t,
|
|
Expected: []string{
|
|
fmt.Sprintf("{\"metrics\":[{\"fields\":{\"usage_idle\":91.5},\"name\":\"cpu\",\"tags\":{\"cpu\":\"cpu0\",\"datacenter\":\"us-west-2\",\"host\":\"localhost\"},\"timestamp\":%d},{\"fields\":{\"usage_idle\":91.5},\"name\":\"cpu\",\"tags\":{\"cpu\":\"cpu0\",\"datacenter\":\"us-west-2\",\"host\":\"localhost\"},\"timestamp\":%d}]}", now.Unix(), now.Unix()),
|
|
},
|
|
})
|
|
|
|
defer server.Close()
|
|
|
|
http := &Http{
|
|
URL: server.URL,
|
|
Headers: map[string]string{
|
|
"Content-Type": "application/json",
|
|
},
|
|
}
|
|
jsonSerializer, _ := json.NewSerializer(time.Second)
|
|
http.SetSerializer(jsonSerializer)
|
|
|
|
m1, _ := metric.New("cpu", cpuTags, cpuField, now)
|
|
m2, _ := metric.New("cpu", cpuTags, cpuField, now)
|
|
metrics := []telegraf.Metric{m1, m2}
|
|
|
|
http.Connect()
|
|
err := http.Write(metrics)
|
|
|
|
assert.Nil(t, err)
|
|
}
|
|
|
|
func TestHttpWithoutContentType(t *testing.T) {
|
|
http := &Http{
|
|
URL: "http://127.0.0.1:56879/correct/url",
|
|
}
|
|
|
|
err := http.Connect()
|
|
|
|
assert.Error(t, err)
|
|
}
|
|
|
|
func TestHttpWithContentType(t *testing.T) {
|
|
http := &Http{
|
|
URL: "http://127.0.0.1:56879/correct/url",
|
|
Headers: map[string]string{
|
|
"Content-Type": "application/json",
|
|
},
|
|
}
|
|
|
|
err := http.Connect()
|
|
|
|
assert.Nil(t, err)
|
|
}
|
|
|
|
func TestImplementedInterfaceFunction(t *testing.T) {
|
|
http := &Http{
|
|
URL: "http://127.0.0.1:56879/incorrect/url",
|
|
Headers: map[string]string{
|
|
"Content-Type": "application/json",
|
|
},
|
|
}
|
|
|
|
assert.NotNil(t, http.SampleConfig())
|
|
assert.NotNil(t, http.Description())
|
|
}
|
|
|
|
func resetCount() {
|
|
count = 0
|
|
}
|