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"
|
2019-10-31 18:16:53 +00:00
|
|
|
"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",
|
|
|
|
},
|
|
|
|
{
|
2019-11-08 00:19:42 +00:00
|
|
|
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
|
|
|
},
|
2019-10-31 18:16:53 +00:00
|
|
|
{
|
2019-11-08 00:19:42 +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",
|
2019-10-31 18:16:53 +00:00
|
|
|
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",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2019-11-08 00:19:42 +00:00
|
|
|
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",
|
2019-10-31 18:16:53 +00:00
|
|
|
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",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2019-11-08 00:19:42 +00:00
|
|
|
{
|
|
|
|
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,
|
2019-10-31 18:16:53 +00:00
|
|
|
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,
|
2019-10-31 18:16:53 +00:00
|
|
|
Children: [2]Node{
|
2019-09-23 16:00:03 +00:00
|
|
|
&LogicalNode{
|
2019-04-09 10:05:42 +00:00
|
|
|
Operator: LogicalAnd,
|
2019-10-31 18:16:53 +00:00
|
|
|
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())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|