93 lines
2.2 KiB
Go
93 lines
2.2 KiB
Go
package reads_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/influxdata/influxdb/v2/storage/reads"
|
|
"github.com/influxdata/influxdb/v2/storage/reads/datatypes"
|
|
)
|
|
|
|
func TestHasFieldValueKey(t *testing.T) {
|
|
predicates := []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.Node_TypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{
|
|
Comparison: datatypes.Node_ComparisonLess,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.Node_TypeFieldRef,
|
|
Value: &datatypes.Node_FieldRefValue{
|
|
FieldRefValue: "_value",
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.Node_TypeLiteral,
|
|
Value: &datatypes.Node_IntegerValue{
|
|
IntegerValue: 3000,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.Node_TypeLogicalExpression,
|
|
Value: &datatypes.Node_Logical_{
|
|
Logical: datatypes.Node_LogicalAnd,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.Node_TypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{
|
|
Comparison: datatypes.Node_ComparisonEqual,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.Node_TypeTagRef,
|
|
Value: &datatypes.Node_TagRefValue{
|
|
TagRefValue: "_measurement",
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.Node_TypeLiteral,
|
|
Value: &datatypes.Node_StringValue{
|
|
StringValue: "cpu",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.Node_TypeComparisonExpression,
|
|
Value: &datatypes.Node_Comparison_{
|
|
Comparison: datatypes.Node_ComparisonLess,
|
|
},
|
|
Children: []*datatypes.Node{
|
|
{
|
|
NodeType: datatypes.Node_TypeFieldRef,
|
|
Value: &datatypes.Node_FieldRefValue{
|
|
FieldRefValue: "_value",
|
|
},
|
|
},
|
|
{
|
|
NodeType: datatypes.Node_TypeLiteral,
|
|
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)
|
|
}
|
|
})
|
|
}
|
|
}
|