Sha256: 52edacddb7ae76979f2e34f9456f93ed4e417272b129a4002d499e91b0617dd1

Contents?: true

Size: 1.72 KB

Versions: 3

Compression:

Stored size: 1.72 KB

Contents

# encoding: utf-8

require 'spec_helper'

describe Optimizer::Algebra::Join::RightMaterializedOperand, '#optimize' do
  subject { object.optimize }

  let(:relation) { left.join(right)              }
  let(:object)   { described_class.new(relation) }

  before do
    object.should be_optimizable
  end

  context 'with no joined tuples' do
    let(:left)  { Relation.new([ [ :id, Integer ],                    ], [].each) }
    let(:right) { Relation.new([ [ :id, Integer ], [ :age,  Integer ] ], [])      }

    it { should be_kind_of(Algebra::Join) }

    its(:left) { should eql(left.restrict { Function::Proposition::Contradiction.instance }) }

    its(:right) { should eql(Relation::Empty.new(right.header)) }
  end

  context 'with one joined tuple' do
    let(:left)  { Relation.new([ [ :id, Integer ],                    ], [ [ 1,    ] ].each) }
    let(:right) { Relation.new([ [ :id, Integer ], [ :age,  Integer ] ], [ [ 1, 35 ] ])      }

    it { should be_kind_of(Algebra::Join) }

    its(:left) { should eql(left.restrict { |r| r.id.eq(1) }) }

    its(:right) { should equal(right) }

    it 'is not further optimizable' do
      described_class.new(subject).should_not be_optimizable
    end
  end

  context 'with two or more joined tuples' do
    let(:left)  { Relation.new([ [ :id, Integer ],                    ], [ [ 1,    ], [ 2,    ] ].each) }
    let(:right) { Relation.new([ [ :id, Integer ], [ :age,  Integer ] ], [ [ 1, 35 ], [ 2, 25 ] ])      }

    it { should be_kind_of(Algebra::Join) }

    its(:left) { should eql(left.restrict { |r| r.id.include([ 1, 2 ]) }) }

    its(:right) { should equal(right) }

    it 'is not further optimizable' do
      described_class.new(subject).should_not be_optimizable
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
veritas-optimizer-0.0.7 spec/unit/veritas/optimizer/algebra/join/right_materialized_operand/optimize_spec.rb
veritas-optimizer-0.0.6 spec/unit/veritas/optimizer/algebra/join/right_materialized_operand/optimize_spec.rb
veritas-optimizer-0.0.5 spec/unit/veritas/optimizer/algebra/join/right_materialized_operand/optimize_spec.rb