This repository has been archived by the owner on Nov 8, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 28
/
logproc_test.go
59 lines (47 loc) · 2.03 KB
/
logproc_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
package main
import (
"strings"
"testing"
log "github.com/Sirupsen/logrus"
)
func TestLogProc(t *testing.T) {
lines := strings.Split(`255 <158>1 2015-04-02T11:52:34.520012+00:00 host heroku router - at=info method=POST path="/users" host=myapp.com request_id=c1806361-2081-42e7-a8aa-92b6808eac8e fwd="24.76.242.18" dyno=web.1 connect=1ms service=37ms status=201 bytes=828
229 <45>1 2015-04-02T11:48:16.839257+00:00 host heroku web.1 - source=web.1 dyno=heroku.35930502.b9de5fce-44b7-4287-99a7-504519070cba sample#load_avg_1m=0.01 sample#load_avg_5m=0.02 sample#load_avg_15m=0.03
222 <134>1 2017-05-13T15:35:33.787162+00:00 host app api - Scaled to mailer@3:Performance-L web@5:Standard-2X by user [email protected]
222 <134>1 2015-04-07T16:01:43.517062+00:00 host heroku api - this_is="broken
222 <134>1 2015-04-07T16:01:43.517062+00:00 host app api - Release v138 created by user foo@bar
222 <134>1 2019-10-08T22:21:03+00:00 app[heroku-redis]: source=REDIS addon=redis-lively-37272 sample#active-connections=14 sample#load-avg-1m=0.505 sample#load-avg-5m=0.87 sample#load-avg-15m=0.77 sample#read-iops=0 sample#write-iops=38.19 sample#memory-total=15664212kB sample#memory-free=9796400kB sample#memory-cached=3751668kB sample#memory-redis=2131576bytes sample#hit-rate=0.78062 sample#evicted-keys=0`, "\n")
app := "test"
tags := []string{"tag1", "tag2"}
prefix := "prefix."
s := loadServerCtx()
s.in = make(chan *logData, 3)
defer close(s.in)
s.out = make(chan *logMetrics, 3)
defer close(s.out)
go logProcess(s.in, s.out)
for i, l := range lines {
log.WithField("line", l).Debug("Sending")
s.in <- &logData{&app, &tags, &prefix, &lines[i]}
}
res := <-s.out
if res.typ != routerMsg {
t.Error("result must be ROUTE")
}
res = <-s.out
if res.typ != sampleMsg {
t.Error("result must be SAMPLE")
}
res = <-s.out
if res.typ != scalingMsg {
t.Error("result must be SCALE")
}
res = <-s.out
if res.typ != releaseMsg {
t.Error("result must be RELEASE")
}
res = <-s.out
if res.typ != sampleMsg {
t.Error("result must be SAMPLE")
}
}