182 lines
4.4 KiB
Go
182 lines
4.4 KiB
Go
|
package papertrail
|
||
|
|
||
|
import (
|
||
|
"net/http"
|
||
|
"net/http/httptest"
|
||
|
"net/url"
|
||
|
"strings"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/influxdata/telegraf/testutil"
|
||
|
"github.com/stretchr/testify/require"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
contentType = "application/x-www-form-urlencoded"
|
||
|
)
|
||
|
|
||
|
func post(pt *PapertrailWebhook, contentType string, body string) *httptest.ResponseRecorder {
|
||
|
req, _ := http.NewRequest("POST", "/", strings.NewReader(body))
|
||
|
req.Header.Set("Content-Type", contentType)
|
||
|
w := httptest.NewRecorder()
|
||
|
pt.eventHandler(w, req)
|
||
|
return w
|
||
|
}
|
||
|
|
||
|
func TestWrongContentType(t *testing.T) {
|
||
|
var acc testutil.Accumulator
|
||
|
pt := &PapertrailWebhook{Path: "/papertrail", acc: &acc}
|
||
|
form := url.Values{}
|
||
|
form.Set("payload", sampleEventPayload)
|
||
|
data := form.Encode()
|
||
|
|
||
|
resp := post(pt, "", data)
|
||
|
require.Equal(t, http.StatusUnsupportedMediaType, resp.Code)
|
||
|
}
|
||
|
|
||
|
func TestMissingPayload(t *testing.T) {
|
||
|
var acc testutil.Accumulator
|
||
|
pt := &PapertrailWebhook{Path: "/papertrail", acc: &acc}
|
||
|
|
||
|
resp := post(pt, contentType, "")
|
||
|
require.Equal(t, http.StatusBadRequest, resp.Code)
|
||
|
}
|
||
|
|
||
|
func TestPayloadNotJSON(t *testing.T) {
|
||
|
var acc testutil.Accumulator
|
||
|
pt := &PapertrailWebhook{Path: "/papertrail", acc: &acc}
|
||
|
|
||
|
resp := post(pt, contentType, "payload={asdf]")
|
||
|
require.Equal(t, http.StatusBadRequest, resp.Code)
|
||
|
}
|
||
|
|
||
|
func TestPayloadInvalidJSON(t *testing.T) {
|
||
|
var acc testutil.Accumulator
|
||
|
pt := &PapertrailWebhook{Path: "/papertrail", acc: &acc}
|
||
|
|
||
|
resp := post(pt, contentType, `payload={"value": 42}`)
|
||
|
require.Equal(t, http.StatusBadRequest, resp.Code)
|
||
|
}
|
||
|
|
||
|
func TestEventPayload(t *testing.T) {
|
||
|
var acc testutil.Accumulator
|
||
|
pt := &PapertrailWebhook{Path: "/papertrail", acc: &acc}
|
||
|
|
||
|
form := url.Values{}
|
||
|
form.Set("payload", sampleEventPayload)
|
||
|
resp := post(pt, contentType, form.Encode())
|
||
|
require.Equal(t, http.StatusOK, resp.Code)
|
||
|
|
||
|
fields := map[string]interface{}{
|
||
|
"count": uint64(1),
|
||
|
}
|
||
|
|
||
|
tags1 := map[string]string{
|
||
|
"event": "Important stuff",
|
||
|
"host": "abc",
|
||
|
}
|
||
|
tags2 := map[string]string{
|
||
|
"event": "Important stuff",
|
||
|
"host": "def",
|
||
|
}
|
||
|
|
||
|
acc.AssertContainsTaggedFields(t, "papertrail", fields, tags1)
|
||
|
acc.AssertContainsTaggedFields(t, "papertrail", fields, tags2)
|
||
|
}
|
||
|
|
||
|
func TestCountPayload(t *testing.T) {
|
||
|
var acc testutil.Accumulator
|
||
|
pt := &PapertrailWebhook{Path: "/papertrail", acc: &acc}
|
||
|
form := url.Values{}
|
||
|
form.Set("payload", sampleCountPayload)
|
||
|
resp := post(pt, contentType, form.Encode())
|
||
|
require.Equal(t, http.StatusOK, resp.Code)
|
||
|
|
||
|
fields1 := map[string]interface{}{
|
||
|
"count": uint64(5),
|
||
|
}
|
||
|
fields2 := map[string]interface{}{
|
||
|
"count": uint64(3),
|
||
|
}
|
||
|
|
||
|
tags1 := map[string]string{
|
||
|
"event": "Important stuff",
|
||
|
"host": "arthur",
|
||
|
}
|
||
|
tags2 := map[string]string{
|
||
|
"event": "Important stuff",
|
||
|
"host": "ford",
|
||
|
}
|
||
|
|
||
|
acc.AssertContainsTaggedFields(t, "papertrail", fields1, tags1)
|
||
|
acc.AssertContainsTaggedFields(t, "papertrail", fields2, tags2)
|
||
|
}
|
||
|
|
||
|
const sampleEventPayload = `{
|
||
|
"events": [
|
||
|
{
|
||
|
"id": 7711561783320576,
|
||
|
"received_at": "2011-05-18T20:30:02-07:00",
|
||
|
"display_received_at": "May 18 20:30:02",
|
||
|
"source_ip": "208.75.57.121",
|
||
|
"source_name": "abc",
|
||
|
"source_id": 2,
|
||
|
"hostname": "abc",
|
||
|
"program": "CROND",
|
||
|
"severity": "Info",
|
||
|
"facility": "Cron",
|
||
|
"message": "message body"
|
||
|
},
|
||
|
{
|
||
|
"id": 7711562567655424,
|
||
|
"received_at": "2011-05-18T20:30:02-07:00",
|
||
|
"display_received_at": "May 18 20:30:02",
|
||
|
"source_ip": "208.75.57.120",
|
||
|
"source_name": "server1",
|
||
|
"source_id": 19,
|
||
|
"hostname": "def",
|
||
|
"program": "CROND",
|
||
|
"severity": "Info",
|
||
|
"facility": "Cron",
|
||
|
"message": "A short event"
|
||
|
}
|
||
|
],
|
||
|
"saved_search": {
|
||
|
"id": 42,
|
||
|
"name": "Important stuff",
|
||
|
"query": "cron OR server1",
|
||
|
"html_edit_url": "https://papertrailapp.com/searches/42/edit",
|
||
|
"html_search_url": "https://papertrailapp.com/searches/42"
|
||
|
},
|
||
|
"max_id": "7711582041804800",
|
||
|
"min_id": "7711561783320576"
|
||
|
}`
|
||
|
|
||
|
const sampleCountPayload = `{
|
||
|
"counts": [
|
||
|
{
|
||
|
"source_name": "arthur",
|
||
|
"source_id": 4,
|
||
|
"timeseries": {
|
||
|
"1453248895": 5
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
"source_name": "ford",
|
||
|
"source_id": 3,
|
||
|
"timeseries": {
|
||
|
"1453248927": 3
|
||
|
}
|
||
|
}
|
||
|
],
|
||
|
"saved_search": {
|
||
|
"id": 42,
|
||
|
"name": "Important stuff",
|
||
|
"query": "cron OR server1",
|
||
|
"html_edit_url": "https://papertrailapp.com/searches/42/edit",
|
||
|
"html_search_url": "https://papertrailapp.com/searches/42"
|
||
|
},
|
||
|
"max_id": "7711582041804800",
|
||
|
"min_id": "7711561783320576"
|
||
|
}`
|