143 lines
3.6 KiB
Go
143 lines
3.6 KiB
Go
package reads_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/influxdata/influxdb/storage/reads"
|
|
"github.com/influxdata/influxdb/storage/reads/datatypes"
|
|
)
|
|
|
|
func TestPredicateToExprString(t *testing.T) {
|
|
cases := []struct {
|
|
n string
|
|
r *datatypes.Predicate
|
|
e string
|
|
}{
|
|
{
|
|
n: "returns [none] for nil",
|
|
r: nil,
|
|
e: "[none]",
|
|
},
|
|
{
|
|
n: "logical AND",
|
|
r: &datatypes.Predicate{
|
|
Root: &datatypes.Node{
|
|
NodeType: datatypes.NodeTypeLogicalExpression,
|
|
Value: &datatypes.Node_Logical_{Logical: datatypes.LogicalAnd},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.NodeTypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
|
|
Children: []*datatypes.Node{
|
|
{NodeType: datatypes.NodeTypeTagRef, Value: &datatypes.Node_TagRefValue{TagRefValue: "host"}},
|
|
{NodeType: datatypes.NodeTypeLiteral, Value: &datatypes.Node_StringValue{StringValue: "host1"}},
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.NodeTypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonRegex},
|
|
Children: []*datatypes.Node{
|
|
{NodeType: datatypes.NodeTypeTagRef, Value: &datatypes.Node_TagRefValue{TagRefValue: "region"}},
|
|
{NodeType: datatypes.NodeTypeLiteral, Value: &datatypes.Node_RegexValue{RegexValue: "^us-west"}},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
e: `'host' = "host1" AND 'region' =~ /^us-west/`,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
t.Run(tc.n, func(t *testing.T) {
|
|
if got, wanted := reads.PredicateToExprString(tc.r), tc.e; got != wanted {
|
|
t.Fatal("got:", got, "wanted:", wanted)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestHasFieldValueKey(t *testing.T) {
|
|
predicates := []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.NodeTypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{
|
|
Comparison: datatypes.ComparisonLess,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.NodeTypeFieldRef,
|
|
Value: &datatypes.Node_FieldRefValue{
|
|
FieldRefValue: "_value",
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.NodeTypeLiteral,
|
|
Value: &datatypes.Node_IntegerValue{
|
|
IntegerValue: 3000,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.NodeTypeLogicalExpression,
|
|
Value: &datatypes.Node_Logical_{
|
|
Logical: datatypes.LogicalAnd,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.NodeTypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{
|
|
Comparison: datatypes.ComparisonEqual,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.NodeTypeTagRef,
|
|
Value: &datatypes.Node_TagRefValue{
|
|
TagRefValue: "_measurement",
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.NodeTypeLiteral,
|
|
Value: &datatypes.Node_StringValue{
|
|
StringValue: "cpu",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.NodeTypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{
|
|
Comparison: datatypes.ComparisonLess,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.NodeTypeFieldRef,
|
|
Value: &datatypes.Node_FieldRefValue{
|
|
FieldRefValue: "_value",
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.NodeTypeLiteral,
|
|
Value: &datatypes.Node_IntegerValue{
|
|
IntegerValue: 3000,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
for _, predicate := range predicates {
|
|
t.Run("", func(t *testing.T) {
|
|
expr, err := reads.NodeToExpr(predicate, nil)
|
|
if err != nil {
|
|
t.Fatalf("unexpected error converting predicate to InfluxQL expression: %v", err)
|
|
}
|
|
if !reads.HasFieldValueKey(expr) {
|
|
t.Fatalf("did not find a field reference in %v", expr)
|
|
}
|
|
})
|
|
}
|
|
}
|