12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- package loggerutils
- import (
- "bufio"
- "context"
- "io"
- "strings"
- "testing"
- "time"
- "github.com/docker/docker/daemon/logger"
- "github.com/docker/docker/pkg/tailfile"
- "gotest.tools/assert"
- )
- func TestTailFiles(t *testing.T) {
- s1 := strings.NewReader("Hello.\nMy name is Inigo Montoya.\n")
- s2 := strings.NewReader("I'm serious.\nDon't call me Shirley!\n")
- s3 := strings.NewReader("Roads?\nWhere we're going we don't need roads.\n")
- files := []SizeReaderAt{s1, s2, s3}
- watcher := logger.NewLogWatcher()
- createDecoder := func(r io.Reader) func() (*logger.Message, error) {
- scanner := bufio.NewScanner(r)
- return func() (*logger.Message, error) {
- if !scanner.Scan() {
- return nil, scanner.Err()
- }
- // some comment
- return &logger.Message{Line: scanner.Bytes(), Timestamp: time.Now()}, nil
- }
- }
- tailReader := func(ctx context.Context, r SizeReaderAt, lines int) (io.Reader, int, error) {
- return tailfile.NewTailReader(ctx, r, lines)
- }
- for desc, config := range map[string]logger.ReadConfig{} {
- t.Run(desc, func(t *testing.T) {
- started := make(chan struct{})
- go func() {
- close(started)
- tailFiles(files, watcher, createDecoder, tailReader, config)
- }()
- <-started
- })
- }
- config := logger.ReadConfig{Tail: 2}
- started := make(chan struct{})
- go func() {
- close(started)
- tailFiles(files, watcher, createDecoder, tailReader, config)
- }()
- <-started
- select {
- case <-time.After(60 * time.Second):
- t.Fatal("timeout waiting for tail line")
- case err := <-watcher.Err:
- assert.Assert(t, err)
- case msg := <-watcher.Msg:
- assert.Assert(t, msg != nil)
- assert.Assert(t, string(msg.Line) == "Roads?", string(msg.Line))
- }
- select {
- case <-time.After(60 * time.Second):
- t.Fatal("timeout waiting for tail line")
- case err := <-watcher.Err:
- assert.Assert(t, err)
- case msg := <-watcher.Msg:
- assert.Assert(t, msg != nil)
- assert.Assert(t, string(msg.Line) == "Where we're going we don't need roads.", string(msg.Line))
- }
- }
|