|
| 1 | +package sinks |
| 2 | + |
| 3 | +import ( |
| 4 | + "context" |
| 5 | + "encoding/json" |
| 6 | + "io" |
| 7 | + "net/http" |
| 8 | + "net/http/httptest" |
| 9 | + "time" |
| 10 | + |
| 11 | + "testing" |
| 12 | + |
| 13 | + "github.com/resmoio/kubernetes-event-exporter/pkg/kube" |
| 14 | + "github.com/stretchr/testify/assert" |
| 15 | + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" |
| 16 | +) |
| 17 | + |
| 18 | +func TestLoki_Send(t *testing.T) { |
| 19 | + ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { |
| 20 | + w.WriteHeader(http.StatusOK) |
| 21 | + })) |
| 22 | + defer ts.Close() |
| 23 | + client := Loki{cfg: &LokiConfig{URL: ts.URL}} |
| 24 | + |
| 25 | + err := client.Send(context.Background(), &kube.EnhancedEvent{}) |
| 26 | + |
| 27 | + assert.NoError(t, err) |
| 28 | +} |
| 29 | + |
| 30 | +func TestLoki_Send_StreamLabelsTemplated(t *testing.T) { |
| 31 | + rr := httptest.NewRecorder() |
| 32 | + ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { |
| 33 | + result, err := io.ReadAll(r.Body) |
| 34 | + if err != nil { |
| 35 | + w.WriteHeader(http.StatusInternalServerError) |
| 36 | + return |
| 37 | + } |
| 38 | + rr.Write(result) |
| 39 | + w.WriteHeader(http.StatusOK) |
| 40 | + })) |
| 41 | + defer ts.Close() |
| 42 | + client := Loki{cfg: &LokiConfig{ |
| 43 | + URL: ts.URL, |
| 44 | + StreamLabels: map[string]string{ |
| 45 | + "app": "kube-events", |
| 46 | + "object_namespace": "{{ .InvolvedObject.Namespace }}", |
| 47 | + }}} |
| 48 | + |
| 49 | + ev := &kube.EnhancedEvent{} |
| 50 | + ev.Namespace = "default" |
| 51 | + ev.Reason = "my reason" |
| 52 | + ev.Type = "Warning" |
| 53 | + ev.InvolvedObject.Kind = "Pod" |
| 54 | + ev.InvolvedObject.Name = "nginx-server-123abc-456def" |
| 55 | + ev.InvolvedObject.Namespace = "prod" |
| 56 | + ev.Message = "Successfully pulled image \"nginx:latest\"" |
| 57 | + ev.FirstTimestamp = v1.Time{Time: time.Now()} |
| 58 | + |
| 59 | + err := client.Send(context.Background(), ev) |
| 60 | + assert.NoError(t, err) |
| 61 | + |
| 62 | + var res LokiMsg |
| 63 | + err = json.Unmarshal(rr.Body.Bytes(), &res) |
| 64 | + assert.NoError(t, err) |
| 65 | + |
| 66 | + assert.Equal(t, res.Streams[0].Stream["app"], "kube-events", "Non template labels should remain the same") |
| 67 | + assert.Equal(t, res.Streams[0].Stream["object_namespace"], "prod", "Template labels should be templated") |
| 68 | +} |
0 commit comments