Documentation ¶
Overview ¶
Package plantest contains utilities for testing each query planning phase
Index ¶
- Constants
- Variables
- func CompareLogicalPlanNodes(p, q plan.Node) error
- func CompareLogicalPlans(p, q *plan.Spec) error
- func ComparePhysicalPlanNodes(p, q plan.Node) error
- func ComparePlans(p, q *plan.Spec, f func(p, q plan.Node) error) error
- func ComparePlansShallow(p, q *plan.Spec) error
- func CreateLogicalMockNode(id string) *plan.LogicalNode
- func CreatePhysicalMockNode(id string) *plan.PhysicalPlanNode
- func CreatePlanSpec(spec *PlanSpec) *plan.Spec
- func LogicalRuleTestHelper(t *testing.T, tc *RuleTestCase)
- func PhysicalRuleTestHelper(t *testing.T, tc *RuleTestCase)
- type CreateCycleRule
- type MockProcedureSpec
- type PlanSpec
- type RuleTestCase
- type SimpleRule
- type SmashPlanRule
Constants ¶
const MockKind = "mock"
Variables ¶
var CmpOptions = append( semantictest.CmpOptions, cmp.AllowUnexported(flux.Spec{}), cmp.AllowUnexported(universe.JoinOpSpec{}), cmpopts.IgnoreUnexported(flux.Spec{}), cmpopts.IgnoreUnexported(universe.JoinOpSpec{}), cmp.AllowUnexported(kafka.ToKafkaProcedureSpec{}), cmpopts.IgnoreUnexported(kafka.ToKafkaProcedureSpec{}), valuestest.ScopeTransformer, )
CmpOptions are the options needed to compare plan.ProcedureSpecs inside plan.Spec.
Functions ¶
func CompareLogicalPlanNodes ¶
CompareLogicalPlanNodes is a comparator function for LogicalPlanNodes
func CompareLogicalPlans ¶
CompareLogicalPlans compares two logical plans.
func ComparePhysicalPlanNodes ¶
ComparePhysicalPlanNodes is a comparator function for PhysicalPlanNodes
func ComparePlans ¶
ComparePlans compares two query plans using an arbitrary comparator function f
func ComparePlansShallow ¶
ComparePlansShallow Compares the two specs, but only compares the metadata and the types of each node. Individual fields of procedure specs are not compared.
func CreateLogicalMockNode ¶
func CreateLogicalMockNode(id string) *plan.LogicalNode
CreateLogicalMockNode creates a mock plan node that doesn't match any rules (other than rules that match any node)
func CreatePhysicalMockNode ¶
func CreatePhysicalMockNode(id string) *plan.PhysicalPlanNode
CreatePhysicalMockNode creates a mock plan node that doesn't match any rules (other than rules that match any node)
func CreatePlanSpec ¶
CreatePlanSpec creates a logical plan from a set of nodes and edges
func LogicalRuleTestHelper ¶
func LogicalRuleTestHelper(t *testing.T, tc *RuleTestCase)
LogicalRuleTestHelper will run a rule test case.
func PhysicalRuleTestHelper ¶
func PhysicalRuleTestHelper(t *testing.T, tc *RuleTestCase)
PhysicalRuleTestHelper will run a rule test case.
Types ¶
type CreateCycleRule ¶
type CreateCycleRule struct { Node plan.Node Kind plan.ProcedureKind }
CreateCycleRule creates a cycle between the given `Node` and its predecessor. It creates exactly one cycle. After the rule is triggered once, it won't have any effect later. This rule breaks the integrity of the plan. If `Kind` is specified, it takes precedence over `Node`, and the rule will use it to match.
func (CreateCycleRule) Name ¶
func (CreateCycleRule) Name() string
func (CreateCycleRule) Pattern ¶
func (ccr CreateCycleRule) Pattern() plan.Pattern
type MockProcedureSpec ¶
type MockProcedureSpec struct {
plan.DefaultCost
}
MockProcedureSpec provides a type that implements ProcedureSpec but does not require importing packages which register rules and procedure kinds, which makes it useful for unit testing.
func (MockProcedureSpec) Copy ¶
func (MockProcedureSpec) Copy() plan.ProcedureSpec
func (MockProcedureSpec) Kind ¶
func (MockProcedureSpec) Kind() plan.ProcedureKind
type PlanSpec ¶
type PlanSpec struct { Nodes []plan.Node // Edges is a list of predecessor-to-successor edges. // [1, 3] => Nodes[1] is a predecessor of Nodes[3]. // Predecessor ordering must be encoded in this list. Edges [][2]int Resources flux.ResourceManagement Now time.Time }
Spec is a set of nodes and edges of a logical query plan
type RuleTestCase ¶
type RuleTestCase struct { Name string Rules []plan.Rule Before *PlanSpec After *PlanSpec NoChange bool ValidateError error }
RuleTestCase allows for concise creation of test cases that exercise rules
type SimpleRule ¶
SimpleRule is a simple rule whose pattern matches any plan node and just stores the NodeIDs of nodes it has visited in SeenNodes.
func (*SimpleRule) Name ¶
func (sr *SimpleRule) Name() string
func (*SimpleRule) Pattern ¶
func (sr *SimpleRule) Pattern() plan.Pattern
type SmashPlanRule ¶
SmashPlanRule adds an `Intruder` as predecessor of the given `Node` without marking it as successor of it. It breaks the integrity of the plan. If `Kind` is specified, it takes precedence over `Node`, and the rule will use it to match.
func (SmashPlanRule) Name ¶
func (SmashPlanRule) Name() string
func (SmashPlanRule) Pattern ¶
func (spp SmashPlanRule) Pattern() plan.Pattern