axiom-optimizer 0.1.0 → 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.rspec +1 -0
- data/.ruby-gemset +1 -0
- data/.travis.yml +4 -6
- data/Gemfile +6 -3
- data/Gemfile.devtools +26 -24
- data/Guardfile +18 -9
- data/README.md +2 -25
- data/axiom-optimizer.gemspec +1 -3
- data/config/devtools.yml +2 -0
- data/config/flay.yml +1 -1
- data/config/flog.yml +1 -1
- data/config/rubocop.yml +53 -0
- data/lib/axiom/optimizer.rb +1 -1
- data/lib/axiom/optimizer/algebra/difference.rb +1 -1
- data/lib/axiom/optimizer/algebra/join.rb +3 -1
- data/lib/axiom/optimizer/algebra/projection.rb +1 -1
- data/lib/axiom/optimizer/algebra/rename.rb +1 -1
- data/lib/axiom/optimizer/algebra/restriction.rb +1 -1
- data/lib/axiom/optimizer/algebra/summarization.rb +1 -1
- data/lib/axiom/optimizer/function/connective/binary.rb +1 -1
- data/lib/axiom/optimizer/optimizable.rb +5 -3
- data/lib/axiom/optimizer/relation/materialized.rb +1 -1
- data/lib/axiom/optimizer/relation/operation/combination.rb +1 -1
- data/lib/axiom/optimizer/relation/operation/limit.rb +2 -2
- data/lib/axiom/optimizer/support/predicate_partition.rb +1 -4
- data/lib/axiom/optimizer/version.rb +1 -1
- data/spec/integration/axiom/algebra/difference/optimize_spec.rb +15 -15
- data/spec/integration/axiom/algebra/intersection/optimize_spec.rb +15 -15
- data/spec/integration/axiom/algebra/join/optimize_spec.rb +11 -11
- data/spec/integration/axiom/algebra/product/optimize_spec.rb +13 -13
- data/spec/integration/axiom/algebra/projection/optimize_spec.rb +44 -44
- data/spec/integration/axiom/algebra/rename/optimize_spec.rb +70 -70
- data/spec/integration/axiom/algebra/restriction/optimize_spec.rb +23 -24
- data/spec/integration/axiom/algebra/summarization/optimize_spec.rb +8 -8
- data/spec/integration/axiom/algebra/union/optimize_spec.rb +21 -21
- data/spec/integration/axiom/function/connective/conjunction/optimize_spec.rb +26 -26
- data/spec/integration/axiom/function/connective/disjunction/optimize_spec.rb +27 -28
- data/spec/integration/axiom/function/connective/negation/optimize_spec.rb +2 -2
- data/spec/integration/axiom/function/optimize_spec.rb +1 -1
- data/spec/integration/axiom/function/predicate/equality/optimize_spec.rb +8 -8
- data/spec/integration/axiom/function/predicate/exclusion/optimize_spec.rb +19 -19
- data/spec/integration/axiom/function/predicate/greater_than/optimize_spec.rb +17 -17
- data/spec/integration/axiom/function/predicate/greater_than_or_equal_to/optimize_spec.rb +17 -17
- data/spec/integration/axiom/function/predicate/inclusion/optimize_spec.rb +19 -19
- data/spec/integration/axiom/function/predicate/inequality/optimize_spec.rb +8 -8
- data/spec/integration/axiom/function/predicate/less_than/optimize_spec.rb +17 -17
- data/spec/integration/axiom/function/predicate/less_than_or_equal_to/optimize_spec.rb +17 -17
- data/spec/integration/axiom/relation/empty/optimize_spec.rb +2 -2
- data/spec/integration/axiom/relation/materialized/optimize_spec.rb +3 -3
- data/spec/integration/axiom/relation/operation/limit/optimize_spec.rb +16 -16
- data/spec/integration/axiom/relation/operation/offset/optimize_spec.rb +14 -14
- data/spec/integration/axiom/relation/operation/order/optimize_spec.rb +11 -11
- data/spec/integration/axiom/relation/operation/reverse/optimize_spec.rb +9 -9
- data/spec/integration/axiom/relation/optimize_spec.rb +4 -4
- data/spec/shared/function_connective_binary_optimize_behavior.rb +18 -18
- data/spec/shared/optimize_method_behavior.rb +2 -2
- data/spec/spec_helper.rb +7 -8
- data/spec/support/add_method_missing.rb +3 -4
- data/spec/unit/axiom/optimizer/algebra/difference/empty_left/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/difference/empty_right/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/difference/equal_operands/optimize_spec.rb +7 -9
- data/spec/unit/axiom/optimizer/algebra/extension/extensions_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/algebra/extension/order_operand/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/algebra/extension/order_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/extension/unoptimized_operand/optimizable_predicate_spec.rb +10 -10
- data/spec/unit/axiom/optimizer/algebra/extension/unoptimized_operand/optimize_spec.rb +10 -10
- data/spec/unit/axiom/optimizer/algebra/intersection/empty_left/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/intersection/empty_right/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/intersection/equal_operands/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/join/disjoint_headers/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/join/disjoint_headers/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/join/equal_headers/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/join/equal_headers/optimize_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/algebra/join/materialized_left/optimizable_predicate_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/algebra/join/materialized_left/optimize_spec.rb +12 -12
- data/spec/unit/axiom/optimizer/algebra/join/materialized_right/optimizable_predicate_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/algebra/join/materialized_right/optimize_spec.rb +12 -12
- data/spec/unit/axiom/optimizer/algebra/product/table_dee_left/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/algebra/product/table_dee_left/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/product/table_dee_right/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/algebra/product/table_dee_right/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/projection/empty_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/projection/empty_operand/optimize_spec.rb +6 -8
- data/spec/unit/axiom/optimizer/algebra/projection/extension_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/projection/extension_operand/optimize_spec.rb +12 -6
- data/spec/unit/axiom/optimizer/algebra/projection/projection_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/projection/projection_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/projection/union_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/projection/union_operand/optimize_spec.rb +10 -10
- data/spec/unit/axiom/optimizer/algebra/projection/unoptimized_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/projection/unoptimized_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/aliases_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/empty_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/rename/empty_operand/optimize_spec.rb +5 -7
- data/spec/unit/axiom/optimizer/algebra/rename/limit_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/rename/limit_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/offset_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/rename/offset_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/order_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/rename/order_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/projection_operand/optimizable_predicate_spec.rb +12 -12
- data/spec/unit/axiom/optimizer/algebra/rename/projection_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/rename_operand/optimizable_predicate_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/algebra/rename/rename_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/rename_operand_and_empty_aliases/optimizable_predicate_spec.rb +11 -11
- data/spec/unit/axiom/optimizer/algebra/rename/rename_operand_and_empty_aliases/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/rename/restriction_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/rename/restriction_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/rename/reverse_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/algebra/rename/reverse_operand/optimize_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/algebra/rename/set_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/rename/set_operand/optimize_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/algebra/rename/unoptimized_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/rename/unoptimized_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/restriction/combination_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/restriction/combination_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/restriction/contradiction/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/restriction/contradiction/optimize_spec.rb +7 -9
- data/spec/unit/axiom/optimizer/algebra/restriction/join_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/restriction/join_operand/optimize_spec.rb +17 -17
- data/spec/unit/axiom/optimizer/algebra/restriction/order_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/restriction/order_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/restriction/predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/restriction/product_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/restriction/product_operand/optimize_spec.rb +17 -17
- data/spec/unit/axiom/optimizer/algebra/restriction/restriction_operand/optimizable_predicate_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/restriction/restriction_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/restriction/set_operand/optimizable_predicate_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/restriction/set_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/restriction/tautology/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/algebra/restriction/tautology/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/restriction/unoptimized_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/algebra/restriction/unoptimized_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/summarization/empty_operand/class_methods/extension_default_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/algebra/summarization/empty_operand/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/summarization/empty_operand/optimize_spec.rb +13 -13
- data/spec/unit/axiom/optimizer/algebra/summarization/empty_summarize_per/optimizable_predicate_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/algebra/summarization/empty_summarize_per/optimize_spec.rb +5 -7
- data/spec/unit/axiom/optimizer/algebra/summarization/order_operand/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/algebra/summarization/order_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/summarization/summarize_per_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/summarization/summarizers_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/algebra/summarization/unoptimized_operand/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/algebra/summarization/unoptimized_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/algebra/union/empty_left/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/union/empty_right/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/algebra/union/equal_operands/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/class_methods/chain_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/function/binary/constant_operands/optimize_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/binary/left_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/binary/right_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/binary/unoptimized_operands/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/function/binary/unoptimized_operands/optimize_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/class_methods/optimize_functions_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/function/class_methods/optimize_operand_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/function/connective/binary/constant_operands/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/binary/equal_operands/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/binary/equal_operands/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/binary/left_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/function/connective/binary/redundant_left/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/connective/binary/redundant_left/optimize_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/connective/binary/redundant_right/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/connective/binary/redundant_right/optimize_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/connective/binary/right_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/function/connective/conjunction/contradiction/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/conjunction/contradiction/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/conjunction/optimizable_to_exclusion/optimizable_predicate_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/function/connective/conjunction/optimizable_to_exclusion/optimize_spec.rb +17 -17
- data/spec/unit/axiom/optimizer/function/connective/conjunction/tautology_left/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/conjunction/tautology_left/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/conjunction/tautology_right/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/conjunction/tautology_right/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/disjunction/contradiction_left/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/disjunction/contradiction_left/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/disjunction/contradiction_right/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/disjunction/contradiction_right/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/disjunction/optimizable_to_inclusion/optimizable_predicate_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/function/connective/disjunction/optimizable_to_inclusion/optimize_spec.rb +17 -17
- data/spec/unit/axiom/optimizer/function/connective/disjunction/tautology/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/disjunction/tautology/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/negation/constant_operand/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/negation/invertible_operand/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/connective/negation/invertible_operand/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/connective/negation/operand_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/function/predicate/comparable/never_comparable/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/predicate/comparable/never_equivalent/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/function/predicate/comparable/normalizable_operands/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/predicate/comparable/normalizable_operands/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/predicate/constant_operands/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/predicate/contradiction/optimize_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/predicate/enumerable/class_methods/sort_by_value_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/predicate/enumerable/empty_right/optimizable_predicate_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/function/predicate/enumerable/one_right/optimizable_predicate_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/function/predicate/enumerable/unoptimized_operands/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/function/predicate/enumerable/unoptimized_operands/optimize_spec.rb +14 -14
- data/spec/unit/axiom/optimizer/function/predicate/equality/tautology/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/predicate/exclusion/empty_right/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/function/predicate/exclusion/one_right/optimize_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/function/predicate/greater_than/contradiction/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/greater_than/tautology/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/greater_than_or_equal_to/contradiction/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/greater_than_or_equal_to/tautology/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/inclusion/empty_right/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/function/predicate/inclusion/one_right/optimize_spec.rb +9 -9
- data/spec/unit/axiom/optimizer/function/predicate/inequality/contradiction/optimizable_predicate_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/predicate/less_than/contradiction/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/less_than/tautology/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/less_than_or_equal_to/contradiction/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/less_than_or_equal_to/tautology/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/function/predicate/tautology/optimize_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/unary/constant_operand/optimize_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/unary/operand_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/unary/unoptimized_operand/optimize_spec.rb +1 -1
- data/spec/unit/axiom/optimizer/function/util/class_methods/max_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/function/util/class_methods/min_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/operation_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/optimizable/class_methods/optimizer_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/optimizable/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/optimizable_predicate_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/optimize_spec.rb +2 -2
- data/spec/unit/axiom/optimizer/predicate_partition/left_spec.rb +18 -18
- data/spec/unit/axiom/optimizer/predicate_partition/remainder_spec.rb +19 -19
- data/spec/unit/axiom/optimizer/predicate_partition/right_spec.rb +18 -18
- data/spec/unit/axiom/optimizer/relation/materialized/empty_operand/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/relation/materialized/empty_operand/optimize_spec.rb +5 -7
- data/spec/unit/axiom/optimizer/relation/operation/binary/empty_left/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/binary/empty_right/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/binary/equal_operands/optimizable_predicate_spec.rb +3 -3
- data/spec/unit/axiom/optimizer/relation/operation/binary/left_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/binary/materialized_operands/optimizable_predicate_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/binary/materialized_operands/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/relation/operation/binary/order_left/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/binary/order_left/optimize_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/relation/operation/binary/order_right/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/binary/order_right/optimize_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/relation/operation/binary/right_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/binary/unoptimized_operands/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/binary/unoptimized_operands/optimize_spec.rb +8 -8
- data/spec/unit/axiom/optimizer/relation/operation/combination/optimize_spec.rb +5 -7
- data/spec/unit/axiom/optimizer/relation/operation/limit/equal_limit_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/limit/equal_limit_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/limit/limit_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/limit/limit_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/limit/unoptimized_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/limit/unoptimized_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/limit/zero_limit/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/limit/zero_limit/optimize_spec.rb +6 -8
- data/spec/unit/axiom/optimizer/relation/operation/offset/offset_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/offset/offset_operand/optimize_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/offset/unoptimized_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/offset/unoptimized_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/offset/zero_offset/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/offset/zero_offset/optimize_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/order/one_limit_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/order/one_limit_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/order/order_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/order/order_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/order/unoptimized_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/order/unoptimized_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/relation/operation/reverse/order_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/reverse/order_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/relation/operation/reverse/reverse_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/reverse/reverse_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/relation/operation/reverse/unoptimized_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/reverse/unoptimized_operand/optimize_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/relation/operation/unary/empty_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/unary/empty_operand/optimize_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/unary/header_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/unary/materialized_operand/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/unary/materialized_operand/optimize_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/unary/operand_spec.rb +7 -7
- data/spec/unit/axiom/optimizer/relation/operation/unary/order_operand/optimizable_predicate_spec.rb +4 -4
- data/spec/unit/axiom/optimizer/relation/operation/unary/order_operand/optimize_spec.rb +6 -6
- data/spec/unit/axiom/optimizer/relation/operation/unary/unchanged_header/optimizable_predicate_spec.rb +5 -5
- data/spec/unit/axiom/optimizer/relation/operation/unary/unchanged_header/optimize_spec.rb +5 -5
- metadata +24 -289
- checksums.yaml +0 -7
- data/.gemtest +0 -0
- data/.rvmrc +0 -1
@@ -5,15 +5,15 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Intersection::EmptyLeft, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:header) { Relation::Header.coerce([
|
9
|
-
let(:left) { Relation::Empty.new(header)
|
10
|
-
let(:right) { Relation.new(header, LazyEnumerable.new([
|
11
|
-
let(:relation) { left.intersect(right)
|
12
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:header) { Relation::Header.coerce([[:id, Integer]]) }
|
9
|
+
let(:left) { Relation::Empty.new(header) }
|
10
|
+
let(:right) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
11
|
+
let(:relation) { left.intersect(right) }
|
12
|
+
let(:object) { described_class.new(relation) }
|
13
13
|
|
14
14
|
before do
|
15
|
-
object.
|
15
|
+
expect(object).to be_optimizable
|
16
16
|
end
|
17
17
|
|
18
|
-
it { should
|
18
|
+
it { should be(left) }
|
19
19
|
end
|
@@ -5,15 +5,15 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Intersection::EmptyRight, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:header) { Relation::Header.coerce([
|
9
|
-
let(:left) { Relation.new(header, LazyEnumerable.new([
|
10
|
-
let(:right) { Relation::Empty.new(header)
|
11
|
-
let(:relation) { left.intersect(right)
|
12
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:header) { Relation::Header.coerce([[:id, Integer]]) }
|
9
|
+
let(:left) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
10
|
+
let(:right) { Relation::Empty.new(header) }
|
11
|
+
let(:relation) { left.intersect(right) }
|
12
|
+
let(:object) { described_class.new(relation) }
|
13
13
|
|
14
14
|
before do
|
15
|
-
object.
|
15
|
+
expect(object).to be_optimizable
|
16
16
|
end
|
17
17
|
|
18
|
-
it { should
|
18
|
+
it { should be(right) }
|
19
19
|
end
|
@@ -5,15 +5,15 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Intersection::EqualOperands, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:header) { Relation::Header.coerce([
|
9
|
-
let(:left) { Relation.new(header, LazyEnumerable.new([
|
10
|
-
let(:right) { Relation.new(header, LazyEnumerable.new([
|
11
|
-
let(:relation) { left.intersect(right)
|
12
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:header) { Relation::Header.coerce([[:id, Integer]]) }
|
9
|
+
let(:left) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
10
|
+
let(:right) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
11
|
+
let(:relation) { left.intersect(right) }
|
12
|
+
let(:object) { described_class.new(relation) }
|
13
13
|
|
14
14
|
before do
|
15
|
-
object.
|
15
|
+
expect(object).to be_optimizable
|
16
16
|
end
|
17
17
|
|
18
|
-
it { should
|
18
|
+
it { should be(left) }
|
19
19
|
end
|
@@ -9,20 +9,20 @@ describe Optimizer::Algebra::Join::DisjointHeaders, '#optimizable?' do
|
|
9
9
|
let(:object) { described_class.new(relation) }
|
10
10
|
|
11
11
|
before do
|
12
|
-
object.operation.
|
12
|
+
expect(object.operation).to be_kind_of(Algebra::Join)
|
13
13
|
end
|
14
14
|
|
15
15
|
context 'when left and right headers are disjoint' do
|
16
|
-
let(:left) { Relation.new([
|
17
|
-
let(:right) { Relation.new([
|
16
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
17
|
+
let(:right) { Relation.new([[:other_id, Integer]], LazyEnumerable.new([[1]])) }
|
18
18
|
|
19
19
|
it { should be(true) }
|
20
20
|
end
|
21
21
|
|
22
22
|
context 'when left and right headers are not disjoint' do
|
23
|
-
let(:header) { [
|
24
|
-
let(:left) { Relation.new(header, LazyEnumerable.new([
|
25
|
-
let(:right) { Relation.new(header, LazyEnumerable.new([
|
23
|
+
let(:header) { [[:id, Integer]] }
|
24
|
+
let(:left) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
25
|
+
let(:right) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
26
26
|
|
27
27
|
it { should be(false) }
|
28
28
|
end
|
@@ -5,18 +5,18 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Join::DisjointHeaders, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:left) { Relation.new([
|
9
|
-
let(:right) { Relation.new([
|
10
|
-
let(:relation) { left.join(right)
|
11
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
9
|
+
let(:right) { Relation.new([[:other_id, Integer]], LazyEnumerable.new([[2]])) }
|
10
|
+
let(:relation) { left.join(right) }
|
11
|
+
let(:object) { described_class.new(relation) }
|
12
12
|
|
13
13
|
before do
|
14
|
-
object.
|
14
|
+
expect(object).to be_optimizable
|
15
15
|
end
|
16
16
|
|
17
17
|
it { should be_kind_of(Algebra::Product) }
|
18
18
|
|
19
|
-
its(:left) { should
|
19
|
+
its(:left) { should be(left) }
|
20
20
|
|
21
|
-
its(:right) { should
|
21
|
+
its(:right) { should be(right) }
|
22
22
|
end
|
@@ -9,20 +9,20 @@ describe Optimizer::Algebra::Join::EqualHeaders, '#optimizable?' do
|
|
9
9
|
let(:object) { described_class.new(relation) }
|
10
10
|
|
11
11
|
before do
|
12
|
-
object.operation.
|
12
|
+
expect(object.operation).to be_kind_of(Algebra::Join)
|
13
13
|
end
|
14
14
|
|
15
15
|
context 'when left and right headers are equal' do
|
16
|
-
let(:header) { Relation::Header.coerce([
|
17
|
-
let(:left) { Relation.new(header, LazyEnumerable.new([
|
18
|
-
let(:right) { Relation.new(header, LazyEnumerable.new([
|
16
|
+
let(:header) { Relation::Header.coerce([[:id, Integer]]) }
|
17
|
+
let(:left) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
18
|
+
let(:right) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
19
19
|
|
20
20
|
it { should be(true) }
|
21
21
|
end
|
22
22
|
|
23
23
|
context 'when left and right headers are not equal' do
|
24
|
-
let(:left) { Relation.new([
|
25
|
-
let(:right) { Relation.new([
|
24
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
25
|
+
let(:right) { Relation.new([[:id, Integer], [:name, String]], LazyEnumerable.new([[1, 'Dan Kubb']])) }
|
26
26
|
|
27
27
|
it { should be(false) }
|
28
28
|
end
|
@@ -5,19 +5,19 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Join::EqualHeaders, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:header) { Relation::Header.coerce([
|
9
|
-
let(:left) { Relation.new(header, LazyEnumerable.new([
|
10
|
-
let(:right) { Relation.new(header, LazyEnumerable.new([
|
11
|
-
let(:relation) { left.join(right)
|
12
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:header) { Relation::Header.coerce([[:id, Integer]]) }
|
9
|
+
let(:left) { Relation.new(header, LazyEnumerable.new([[1]])) }
|
10
|
+
let(:right) { Relation.new(header, LazyEnumerable.new([[2]])) }
|
11
|
+
let(:relation) { left.join(right) }
|
12
|
+
let(:object) { described_class.new(relation) }
|
13
13
|
|
14
14
|
before do
|
15
|
-
object.
|
15
|
+
expect(object).to be_optimizable
|
16
16
|
end
|
17
17
|
|
18
18
|
it { should be_kind_of(Algebra::Intersection) }
|
19
19
|
|
20
|
-
its(:left) { should
|
20
|
+
its(:left) { should be(left) }
|
21
21
|
|
22
|
-
its(:right) { should
|
22
|
+
its(:right) { should be(right) }
|
23
23
|
end
|
@@ -9,33 +9,33 @@ describe Optimizer::Algebra::Join::MaterializedLeft, '#optimizable?' do
|
|
9
9
|
let(:object) { described_class.new(relation) }
|
10
10
|
|
11
11
|
before do
|
12
|
-
object.operation.
|
12
|
+
expect(object.operation).to be_kind_of(Algebra::Join)
|
13
13
|
end
|
14
14
|
|
15
15
|
context 'when the left is materialized and right is not a restriction' do
|
16
|
-
let(:left) { Relation.new([
|
17
|
-
let(:right) { Relation.new([
|
16
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], [[1, 'Dan Kubb']]) }
|
17
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35]])) }
|
18
18
|
|
19
19
|
it { should be(true) }
|
20
20
|
end
|
21
21
|
|
22
22
|
context 'when the left is materialized and right is a restriction not matching the left' do
|
23
|
-
let(:left) { Relation.new([
|
24
|
-
let(:right) { Relation.new([
|
23
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], [[1, 'Dan Kubb']]) }
|
24
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35]])).restrict { |r| r.age.eq(35) } }
|
25
25
|
|
26
26
|
it { should be(true) }
|
27
27
|
end
|
28
28
|
|
29
29
|
context 'when the left is materialized and right is a restriction matching the left' do
|
30
|
-
let(:left) { Relation.new([
|
31
|
-
let(:right) { Relation.new([
|
30
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], [[1, 'Dan Kubb']]) }
|
31
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35]])).restrict { |r| r.id.eq(1) } }
|
32
32
|
|
33
33
|
it { should be(false) }
|
34
34
|
end
|
35
35
|
|
36
36
|
context 'when the left is not materialized' do
|
37
|
-
let(:left) { Relation.new([
|
38
|
-
let(:right) { Relation.new([
|
37
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], LazyEnumerable.new([[1, 'Dan Kubb']])) }
|
38
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35]])) }
|
39
39
|
|
40
40
|
it { should be(false) }
|
41
41
|
end
|
@@ -9,12 +9,12 @@ describe Optimizer::Algebra::Join::MaterializedLeft, '#optimize' do
|
|
9
9
|
let(:object) { described_class.new(relation) }
|
10
10
|
|
11
11
|
before do
|
12
|
-
object.
|
12
|
+
expect(object).to be_optimizable
|
13
13
|
end
|
14
14
|
|
15
15
|
context 'with no joined tuples' do
|
16
|
-
let(:left) { Relation.new([
|
17
|
-
let(:right) { Relation.new([
|
16
|
+
let(:left) { Relation.new([[:id, Integer]], []) }
|
17
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new) }
|
18
18
|
|
19
19
|
it { should be_kind_of(Algebra::Join) }
|
20
20
|
|
@@ -24,32 +24,32 @@ describe Optimizer::Algebra::Join::MaterializedLeft, '#optimize' do
|
|
24
24
|
end
|
25
25
|
|
26
26
|
context 'with one joined tuple' do
|
27
|
-
let(:left) { Relation.new([
|
28
|
-
let(:right) { Relation.new([
|
27
|
+
let(:left) { Relation.new([[:id, Integer]], [[1]]) }
|
28
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35]])) }
|
29
29
|
|
30
30
|
it { should be_kind_of(Algebra::Join) }
|
31
31
|
|
32
|
-
its(:left) { should
|
32
|
+
its(:left) { should be(left) }
|
33
33
|
|
34
34
|
its(:right) { should eql(right.restrict { |r| r.id.eq(1) }) }
|
35
35
|
|
36
36
|
it 'is not further optimizable' do
|
37
|
-
described_class.new(subject).
|
37
|
+
expect(described_class.new(subject)).to_not be_optimizable
|
38
38
|
end
|
39
39
|
end
|
40
40
|
|
41
41
|
context 'with two or more joined tuples' do
|
42
|
-
let(:left) { Relation.new([
|
43
|
-
let(:right) { Relation.new([
|
42
|
+
let(:left) { Relation.new([[:id, Integer]], [[1], [2]]) }
|
43
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35], [2, 25]])) }
|
44
44
|
|
45
45
|
it { should be_kind_of(Algebra::Join) }
|
46
46
|
|
47
|
-
its(:left) { should
|
47
|
+
its(:left) { should be(left) }
|
48
48
|
|
49
|
-
its(:right) { should eql(right.restrict { |r| r.id.include([
|
49
|
+
its(:right) { should eql(right.restrict { |r| r.id.include([1, 2]) }) }
|
50
50
|
|
51
51
|
it 'is not further optimizable' do
|
52
|
-
described_class.new(subject).
|
52
|
+
expect(described_class.new(subject)).to_not be_optimizable
|
53
53
|
end
|
54
54
|
end
|
55
55
|
end
|
data/spec/unit/axiom/optimizer/algebra/join/materialized_right/optimizable_predicate_spec.rb
CHANGED
@@ -9,33 +9,33 @@ describe Optimizer::Algebra::Join::MaterializedRight, '#optimizable?' do
|
|
9
9
|
let(:object) { described_class.new(relation) }
|
10
10
|
|
11
11
|
before do
|
12
|
-
object.operation.
|
12
|
+
expect(object.operation).to be_kind_of(Algebra::Join)
|
13
13
|
end
|
14
14
|
|
15
15
|
context 'when the right is materialized and left is not a restriction' do
|
16
|
-
let(:left) { Relation.new([
|
17
|
-
let(:right) { Relation.new([
|
16
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], LazyEnumerable.new([[1, 'Dan Kubb']])) }
|
17
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], [[1, 35]]) }
|
18
18
|
|
19
19
|
it { should be(true) }
|
20
20
|
end
|
21
21
|
|
22
22
|
context 'when the right is materialized and left is a restriction not matching the right' do
|
23
|
-
let(:left) { Relation.new([
|
24
|
-
let(:right) { Relation.new([
|
23
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], LazyEnumerable.new([[1, 'Dan Kubb']])).restrict { |r| r.name.eq('Dan Kubb') } }
|
24
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], [[1, 35]]) }
|
25
25
|
|
26
26
|
it { should be(true) }
|
27
27
|
end
|
28
28
|
|
29
29
|
context 'when the right is materialized and left is a restriction matching the right' do
|
30
|
-
let(:left) { Relation.new([
|
31
|
-
let(:right) { Relation.new([
|
30
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], LazyEnumerable.new([[1, 'Dan Kubb']])).restrict { |r| r.id.eq(1) } }
|
31
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], [[1, 35]]) }
|
32
32
|
|
33
33
|
it { should be(false) }
|
34
34
|
end
|
35
35
|
|
36
36
|
context 'when the left is not materialized' do
|
37
|
-
let(:left) { Relation.new([
|
38
|
-
let(:right) { Relation.new([
|
37
|
+
let(:left) { Relation.new([[:id, Integer], [:name, String]], LazyEnumerable.new([[1, 'Dan Kubb']])) }
|
38
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], LazyEnumerable.new([[1, 35]])) }
|
39
39
|
|
40
40
|
it { should be(false) }
|
41
41
|
end
|
@@ -9,12 +9,12 @@ describe Optimizer::Algebra::Join::MaterializedRight, '#optimize' do
|
|
9
9
|
let(:object) { described_class.new(relation) }
|
10
10
|
|
11
11
|
before do
|
12
|
-
object.
|
12
|
+
expect(object).to be_optimizable
|
13
13
|
end
|
14
14
|
|
15
15
|
context 'with no joined tuples' do
|
16
|
-
let(:left) { Relation.new([
|
17
|
-
let(:right) { Relation.new([
|
16
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new) }
|
17
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], []) }
|
18
18
|
|
19
19
|
it { should be_kind_of(Algebra::Join) }
|
20
20
|
|
@@ -24,32 +24,32 @@ describe Optimizer::Algebra::Join::MaterializedRight, '#optimize' do
|
|
24
24
|
end
|
25
25
|
|
26
26
|
context 'with one joined tuple' do
|
27
|
-
let(:left) { Relation.new([
|
28
|
-
let(:right) { Relation.new([
|
27
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
28
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], [[1, 35]]) }
|
29
29
|
|
30
30
|
it { should be_kind_of(Algebra::Join) }
|
31
31
|
|
32
32
|
its(:left) { should eql(left.restrict { |r| r.id.eq(1) }) }
|
33
33
|
|
34
|
-
its(:right) { should
|
34
|
+
its(:right) { should be(right) }
|
35
35
|
|
36
36
|
it 'is not further optimizable' do
|
37
|
-
described_class.new(subject).
|
37
|
+
expect(described_class.new(subject)).to_not be_optimizable
|
38
38
|
end
|
39
39
|
end
|
40
40
|
|
41
41
|
context 'with two or more joined tuples' do
|
42
|
-
let(:left) { Relation.new([
|
43
|
-
let(:right) { Relation.new([
|
42
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1], [2]])) }
|
43
|
+
let(:right) { Relation.new([[:id, Integer], [:age, Integer]], [[1, 35], [2, 25]]) }
|
44
44
|
|
45
45
|
it { should be_kind_of(Algebra::Join) }
|
46
46
|
|
47
|
-
its(:left) { should eql(left.restrict { |r| r.id.include([
|
47
|
+
its(:left) { should eql(left.restrict { |r| r.id.include([1, 2]) }) }
|
48
48
|
|
49
|
-
its(:right) { should
|
49
|
+
its(:right) { should be(right) }
|
50
50
|
|
51
51
|
it 'is not further optimizable' do
|
52
|
-
described_class.new(subject).
|
52
|
+
expect(described_class.new(subject)).to_not be_optimizable
|
53
53
|
end
|
54
54
|
end
|
55
55
|
end
|
@@ -5,12 +5,12 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Product::TableDeeLeft, '#optimizable?' do
|
6
6
|
subject { object.optimizable? }
|
7
7
|
|
8
|
-
let(:right) { Relation.new([
|
9
|
-
let(:relation) { left.product(right)
|
10
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:right) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
9
|
+
let(:relation) { left.product(right) }
|
10
|
+
let(:object) { described_class.new(relation) }
|
11
11
|
|
12
12
|
before do
|
13
|
-
object.operation.
|
13
|
+
expect(object.operation).to be_kind_of(Algebra::Product)
|
14
14
|
end
|
15
15
|
|
16
16
|
context 'when the left operand is a table dee' do
|
@@ -5,14 +5,14 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Product::TableDeeLeft, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:left) { TABLE_DEE
|
9
|
-
let(:right) { Relation.new([
|
10
|
-
let(:relation) { left.product(right)
|
11
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:left) { TABLE_DEE }
|
9
|
+
let(:right) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
10
|
+
let(:relation) { left.product(right) }
|
11
|
+
let(:object) { described_class.new(relation) }
|
12
12
|
|
13
13
|
before do
|
14
|
-
object.
|
14
|
+
expect(object).to be_optimizable
|
15
15
|
end
|
16
16
|
|
17
|
-
it { should
|
17
|
+
it { should be(right) }
|
18
18
|
end
|
data/spec/unit/axiom/optimizer/algebra/product/table_dee_right/optimizable_predicate_spec.rb
CHANGED
@@ -5,12 +5,12 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Product::TableDeeRight, '#optimizable?' do
|
6
6
|
subject { object.optimizable? }
|
7
7
|
|
8
|
-
let(:left) { Relation.new([
|
9
|
-
let(:relation) { left.product(right)
|
10
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
9
|
+
let(:relation) { left.product(right) }
|
10
|
+
let(:object) { described_class.new(relation) }
|
11
11
|
|
12
12
|
before do
|
13
|
-
object.operation.
|
13
|
+
expect(object.operation).to be_kind_of(Algebra::Product)
|
14
14
|
end
|
15
15
|
|
16
16
|
context 'when the right operand is a table dee' do
|
@@ -5,14 +5,14 @@ require 'spec_helper'
|
|
5
5
|
describe Optimizer::Algebra::Product::TableDeeRight, '#optimize' do
|
6
6
|
subject { object.optimize }
|
7
7
|
|
8
|
-
let(:left) { Relation.new([
|
9
|
-
let(:right) { TABLE_DEE
|
10
|
-
let(:relation) { left.product(right)
|
11
|
-
let(:object) { described_class.new(relation)
|
8
|
+
let(:left) { Relation.new([[:id, Integer]], LazyEnumerable.new([[1]])) }
|
9
|
+
let(:right) { TABLE_DEE }
|
10
|
+
let(:relation) { left.product(right) }
|
11
|
+
let(:object) { described_class.new(relation) }
|
12
12
|
|
13
13
|
before do
|
14
|
-
object.
|
14
|
+
expect(object).to be_optimizable
|
15
15
|
end
|
16
16
|
|
17
|
-
it { should
|
17
|
+
it { should be(left) }
|
18
18
|
end
|