Sha256: 29920899e785c7d2f06b6526f9b5a4e847236f612dfd1fa48f104c0c70b3bae6

Contents?: true

Size: 1.81 KB

Versions: 2

Compression:

Stored size: 1.81 KB

Contents

# encoding: utf-8

require 'spec_helper'

describe Optimizer::Algebra::Restriction::JoinOperand, '#optimizable?' do
  subject { object.optimizable? }

  let(:left)     { Relation.new([[:id, Integer], [:user_name, String]], LazyEnumerable.new([[1, 'Dan Kubb']]))     }
  let(:right)    { Relation.new([[:id, Integer], [:employee_name, String]], LazyEnumerable.new([[2, 'Dan Kubb']])) }
  let(:relation) { operand.restrict { predicate }                                                                  }
  let(:object)   { described_class.new(relation)                                                                   }

  before do
    expect(object.operation).to be_kind_of(Algebra::Restriction)
  end

  context 'when the operand is a join operation and the predicate distributes to the left' do
    let(:operand)   { left.join(right)                }
    let(:predicate) { left[:user_name].eq('Dan Kubb') }

    it { should be(true) }
  end

  context 'when the operand is a join operation and the predicate distributes to the right' do
    let(:operand)   { left.join(right)                     }
    let(:predicate) { right[:employee_name].eq('Dan Kubb') }

    it { should be(true) }
  end

  context 'when the operand is a join operation and the predicate distributes to the left and right' do
    let(:operand)   { left.join(right) }
    let(:predicate) { left[:id].eq(1)  }

    it { should be(true) }
  end

  context 'when the operand is a join operation and the predicate does not distribute to the left or right' do
    let(:operand)   { left.join(right)                           }
    let(:predicate) { left[:user_name].eq(right[:employee_name]) }

    it { should be(false) }
  end

  context 'when the operand is not a join operation' do
    let(:operand)   { left }
    let(:predicate) { true }

    it { should be(false) }
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
axiom-optimizer-0.2.0 spec/unit/axiom/optimizer/algebra/restriction/join_operand/optimizable_predicate_spec.rb
axiom-optimizer-0.1.1 spec/unit/axiom/optimizer/algebra/restriction/join_operand/optimizable_predicate_spec.rb