VictoriaMetrics/lib/logstorage/fields_set_test.go

109 lines
2.5 KiB
Go
Raw Normal View History

2024-05-09 00:52:28 +00:00
package logstorage
import (
"reflect"
"testing"
)
func TestFieldsSet(t *testing.T) {
fs := newFieldsSet()
// verify add, remove and contains
if fs.contains("*") {
t.Fatalf("fs mustn't contain *")
}
if fs.contains("foo") {
t.Fatalf("fs musn't contain foo")
}
fs.add("foo")
fs.add("bar")
2024-05-17 02:11:10 +00:00
fs.add("")
2024-05-09 00:52:28 +00:00
s := fs.String()
2024-05-17 02:11:10 +00:00
if s != "[_msg,bar,foo]" {
t.Fatalf("unexpected String() result; got %s; want %s", s, "[_msg,bar,foo]")
2024-05-09 00:52:28 +00:00
}
if !fs.contains("foo") {
t.Fatalf("fs must contain foo")
}
if !fs.contains("bar") {
t.Fatalf("fs must contain bar")
}
2024-05-17 02:11:10 +00:00
if !fs.contains("") {
t.Fatalf("fs must contain _msg")
}
if !fs.contains("_msg") {
t.Fatalf("fs must contain _msg")
}
2024-05-09 00:52:28 +00:00
if fs.contains("baz") {
t.Fatalf("fs musn't contain baz")
}
if fs.contains("*") {
t.Fatalf("fs mustn't contain *")
}
fs.remove("foo")
if fs.contains("foo") {
t.Fatalf("fs mustn't contain foo")
}
fs.remove("bar")
if fs.contains("bar") {
t.Fatalf("fs mustn't contain bar")
}
2024-05-17 02:11:10 +00:00
fs.remove("")
if fs.contains("") {
t.Fatalf("fs mustn't contain _msg")
}
if fs.contains("_msg") {
t.Fatalf("fs mustn't contain _msg")
}
2024-05-09 00:52:28 +00:00
// verify *
fs.add("*")
if !fs.contains("*") {
t.Fatalf("fs must contain *")
}
if !fs.contains("foo") || !fs.contains("bar") || !fs.contains("baz") {
t.Fatalf("fs must contain anything")
}
fs.remove("foo")
if !fs.contains("foo") {
t.Fatalf("fs must contain anything")
}
fs.remove("*")
if fs.contains("foo") || fs.contains("bar") || fs.contains("baz") {
t.Fatalf("fs must be empty")
}
2024-05-17 09:32:27 +00:00
// verify addFields, removeFields, getAll
fs.addFields([]string{"foo", "bar", "_msg"})
2024-05-17 02:11:10 +00:00
if !fs.contains("foo") || !fs.contains("bar") || !fs.contains("_msg") {
t.Fatalf("fs must contain foo, bar and _msg")
2024-05-09 00:52:28 +00:00
}
a := fs.getAll()
2024-05-17 02:11:10 +00:00
if !reflect.DeepEqual(a, []string{"_msg", "bar", "foo"}) {
t.Fatalf("unexpected result from getAll(); got %q; want %q", a, []string{"_msg", "bar", "foo"})
2024-05-09 00:52:28 +00:00
}
2024-05-17 09:32:27 +00:00
fs.removeFields([]string{"bar", "baz", "_msg"})
2024-05-17 02:11:10 +00:00
if fs.contains("bar") || fs.contains("baz") || fs.contains("_msg") {
t.Fatalf("fs mustn't contain bar, baz and _msg")
2024-05-09 00:52:28 +00:00
}
if !fs.contains("foo") {
t.Fatalf("fs must contain foo")
}
// verify clone
2024-05-17 09:32:27 +00:00
fs.addFields([]string{"foo", "bar", "baz"})
2024-05-09 00:52:28 +00:00
fsStr := fs.String()
fsCopy := fs.clone()
fsCopyStr := fsCopy.String()
if fsStr != fsCopyStr {
t.Fatalf("unexpected clone result; got %s; want %s", fsCopyStr, fsStr)
}
fsCopy.remove("foo")
if fsCopy.contains("foo") {
t.Fatalf("fsCopy mustn't contain foo")
}
if !fs.contains("foo") {
t.Fatalf("fs must contain foo")
}
}