blob: d53b53b5ab680cfc55042921fac9978f16822840 [file] [log] [blame]
// Copyright The Monogon Project Authors.
// SPDX-License-Identifier: Apache-2.0
package logbuffer
import (
"testing"
"github.com/stretchr/testify/require"
)
func TestSingleLine(t *testing.T) {
buf := New(1, 16000)
buf.Write([]byte("Hello World\n"))
out := buf.ReadLines(1)
require.Len(t, out, 1, "Invalid number of lines read")
require.Equal(t, "Hello World", out[0].Data, "Read bad log line")
require.Equal(t, 11, out[0].OriginalLength, "Invalid line length")
}
func TestPartialWritesAndReads(t *testing.T) {
buf := New(2, 16000)
buf.Write([]byte("Hello "))
buf.Write([]byte("World\nTest "))
buf.Write([]byte("2\n"))
out := buf.ReadLines(1)
require.Len(t, out, 1, "Invalid number of lines for partial read")
require.Equal(t, "Test 2", out[0].Data, "Read bad log line")
out2 := buf.ReadLines(2)
require.Len(t, out2, 2, "Invalid number of lines read")
require.Equal(t, "Hello World", out2[0].Data, "Read bad log line")
require.Equal(t, "Test 2", out2[1].Data, "Read bad log line")
}
func TestBufferOverwrite(t *testing.T) {
buf := New(3, 16000)
buf.Write([]byte("Test1\nTest2\nTest3\nTest4\n"))
out := buf.ReadLines(3)
require.Equal(t, out[0].Data, "Test2", "Read bad log line")
require.Equal(t, out[1].Data, "Test3", "Read bad log line")
require.Equal(t, out[2].Data, "Test4", "Overwritten data is invalid")
}
func TestTooLargeRequests(t *testing.T) {
buf := New(1, 16000)
outEmpty := buf.ReadLines(1)
require.Len(t, outEmpty, 0, "Returned more data than there is")
buf.Write([]byte("1\n2\n"))
out := buf.ReadLines(2)
require.Len(t, out, 1, "Returned more data than the ring buffer can hold")
}
func TestSpecialCases(t *testing.T) {
buf := New(2, 16000)
buf.Write([]byte("Test1"))
buf.Write([]byte("\nTest2\n"))
out := buf.ReadLines(2)
require.Len(t, out, 2, "Too many lines written")
require.Equal(t, out[0].Data, "Test1", "Read bad log line")
require.Equal(t, out[1].Data, "Test2", "Read bad log line")
}
func TestLineLengthLimit(t *testing.T) {
buf := New(2, 6)
testStr := "Just Testing"
buf.Write([]byte(testStr + "\nShort\n"))
out := buf.ReadLines(2)
require.Equal(t, len(testStr), out[0].OriginalLength, "Line is over length limit")
require.Equal(t, "Just T", out[0].Data, "Log line not properly truncated")
out2 := buf.ReadLinesTruncated(2, "...")
require.Equal(t, out2[0], "Just T...", "Line is over length limit")
require.Equal(t, out2[1], "Short", "Truncated small enough line")
}