influxdb/predicate/predicate_test.go

357 lines
8.7 KiB
Go
Raw Normal View History

2019-09-23 16:00:03 +00:00
package predicate
import (
"testing"
2019-10-14 21:33:50 +00:00
"github.com/google/go-cmp/cmp"
2019-09-23 16:00:03 +00:00
"github.com/influxdata/influxdb"
"github.com/influxdata/influxdb/models"
2019-04-09 10:05:42 +00:00
"github.com/influxdata/influxdb/storage/reads/datatypes"
2019-09-23 16:00:03 +00:00
influxtesting "github.com/influxdata/influxdb/testing"
)
2019-10-14 21:33:50 +00:00
func TestDataTypeConversion(t *testing.T) {
2019-09-23 16:00:03 +00:00
cases := []struct {
2019-04-09 10:05:42 +00:00
name string
node Node
2019-10-14 21:33:50 +00:00
err error
2019-04-09 10:05:42 +00:00
dataType *datatypes.Node
2019-09-23 16:00:03 +00:00
}{
{
name: "empty node",
},
{
name: "equal tag rule",
2019-09-23 16:00:03 +00:00
node: &TagRuleNode{
Operator: influxdb.Equal,
Tag: influxdb.Tag{
Key: "k1",
Value: "v1",
},
},
2019-04-09 10:05:42 +00:00
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: "k1"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v1",
},
},
},
},
2019-09-23 16:00:03 +00:00
},
{
name: "not equal tag rule",
node: &TagRuleNode{
Operator: influxdb.NotEqual,
Tag: influxdb.Tag{
Key: "k1",
Value: "v1",
},
},
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonNotEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: "k1"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v1",
},
},
},
},
},
{
name: "measurement equal tag rule",
node: &TagRuleNode{
Operator: influxdb.Equal,
Tag: influxdb.Tag{
Key: "_measurement",
Value: "cpu",
},
},
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: models.MeasurementTagKey},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "cpu",
},
},
},
},
},
{
name: "measurement not equal tag rule",
node: &TagRuleNode{
Operator: influxdb.NotEqual,
Tag: influxdb.Tag{
Key: "_measurement",
Value: "cpu",
},
},
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonNotEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: models.MeasurementTagKey},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "cpu",
},
},
},
},
},
{
name: "equal field tag rule",
node: &TagRuleNode{
Operator: influxdb.Equal,
Tag: influxdb.Tag{
Key: "_field",
Value: "cpu",
},
},
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: models.FieldKeyTagKey},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "cpu",
},
},
},
},
},
{
name: "not equal field tag rule",
node: &TagRuleNode{
Operator: influxdb.NotEqual,
Tag: influxdb.Tag{
Key: "_field",
Value: "cpu",
},
},
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonNotEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: models.FieldKeyTagKey},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "cpu",
},
},
},
},
},
2019-09-23 16:00:03 +00:00
{
name: "logical",
node: &LogicalNode{
Operator: LogicalAnd,
Children: [2]Node{
2019-09-23 16:00:03 +00:00
&TagRuleNode{
Operator: influxdb.Equal,
Tag: influxdb.Tag{
Key: "k1",
Value: "v1",
},
},
&TagRuleNode{
2019-04-09 10:05:42 +00:00
Operator: influxdb.Equal,
2019-09-23 16:00:03 +00:00
Tag: influxdb.Tag{
Key: "k2",
2019-04-09 10:05:42 +00:00
Value: "v2",
},
},
},
},
dataType: &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: "k1"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v1",
},
},
},
},
{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: "k2"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v2",
},
},
2019-09-23 16:00:03 +00:00
},
},
},
},
},
{
name: "conplex logical",
node: &LogicalNode{
Operator: LogicalAnd,
Children: [2]Node{
2019-09-23 16:00:03 +00:00
&LogicalNode{
2019-04-09 10:05:42 +00:00
Operator: LogicalAnd,
Children: [2]Node{
2019-09-23 16:00:03 +00:00
&TagRuleNode{
Operator: influxdb.Equal,
Tag: influxdb.Tag{
Key: "k3",
Value: "v3",
},
},
&TagRuleNode{
Operator: influxdb.Equal,
Tag: influxdb.Tag{
Key: "k4",
Value: "v4",
},
},
},
},
&TagRuleNode{
2019-04-09 10:05:42 +00:00
Operator: influxdb.Equal,
2019-09-23 16:00:03 +00:00
Tag: influxdb.Tag{
Key: "k2",
2019-04-09 10:05:42 +00:00
Value: "v2",
},
},
},
},
dataType: &datatypes.Node{
NodeType: datatypes.NodeTypeLogicalExpression,
Value: &datatypes.Node_Logical_{
Logical: datatypes.LogicalAnd,
},
Children: []*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: "k3"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v3",
},
},
},
},
{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: "k4"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v4",
},
},
},
},
},
},
{
NodeType: datatypes.NodeTypeComparisonExpression,
Value: &datatypes.Node_Comparison_{Comparison: datatypes.ComparisonEqual},
Children: []*datatypes.Node{
{
NodeType: datatypes.NodeTypeTagRef,
Value: &datatypes.Node_TagRefValue{TagRefValue: "k2"},
},
{
NodeType: datatypes.NodeTypeLiteral,
Value: &datatypes.Node_StringValue{
StringValue: "v2",
},
},
2019-09-23 16:00:03 +00:00
},
},
},
},
},
}
for _, c := range cases {
2019-10-14 21:33:50 +00:00
if c.node != nil {
dataType, err := c.node.ToDataType()
influxtesting.ErrorsEqual(t, err, c.err)
if c.err != nil {
continue
2019-04-09 10:05:42 +00:00
}
if diff := cmp.Diff(dataType, c.dataType); diff != "" {
t.Fatalf("%s failed nodes are different, diff: %s", c.name, diff)
}
}
2019-10-14 21:33:50 +00:00
if _, err := New(c.node); err != nil {
2019-09-23 16:00:03 +00:00
t.Fatalf("%s convert to predicate failed, err: %s", c.name, err.Error())
}
}
}