2013-12-30 22:42:41 +00:00
|
|
|
package agent
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
"time"
|
2016-11-04 04:14:56 +00:00
|
|
|
|
|
|
|
"github.com/hashicorp/consul/logger"
|
|
|
|
"github.com/hashicorp/logutils"
|
2013-12-30 22:42:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type MockStreamClient struct {
|
|
|
|
headers []*responseHeader
|
|
|
|
objs []interface{}
|
|
|
|
err error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *MockStreamClient) Send(h *responseHeader, o interface{}) error {
|
|
|
|
m.headers = append(m.headers, h)
|
|
|
|
m.objs = append(m.objs, o)
|
|
|
|
return m.err
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRPCLogStream(t *testing.T) {
|
|
|
|
sc := &MockStreamClient{}
|
2016-11-04 04:14:56 +00:00
|
|
|
filter := logger.LevelFilter()
|
2013-12-30 22:42:41 +00:00
|
|
|
filter.MinLevel = logutils.LogLevel("INFO")
|
|
|
|
|
|
|
|
ls := newLogStream(sc, filter, 42, log.New(os.Stderr, "", log.LstdFlags))
|
|
|
|
defer ls.Stop()
|
|
|
|
|
|
|
|
log := "[DEBUG] this is a test log"
|
|
|
|
log2 := "[INFO] This should pass"
|
|
|
|
ls.HandleLog(log)
|
|
|
|
ls.HandleLog(log2)
|
|
|
|
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
|
|
|
|
|
|
|
if len(sc.headers) != 1 {
|
|
|
|
t.Fatalf("expected 1 messages!")
|
|
|
|
}
|
|
|
|
for _, h := range sc.headers {
|
|
|
|
if h.Seq != 42 {
|
|
|
|
t.Fatalf("bad seq")
|
|
|
|
}
|
|
|
|
if h.Error != "" {
|
|
|
|
t.Fatalf("bad err")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
obj1 := sc.objs[0].(*logRecord)
|
|
|
|
if obj1.Log != log2 {
|
|
|
|
t.Fatalf("bad event %#v", obj1)
|
|
|
|
}
|
|
|
|
}
|