Sha256: 0155241e7e67e09bf54bf8e7321202f26cad908ef8d0d01c4ce1ad9fddc8aed9

Contents?: true

Size: 1.73 KB

Versions: 2

Compression:

Stored size: 1.73 KB

Contents

# encoding: utf-8

require 'spec_helper'

describe Optimizer::Algebra::Summarization::UnoptimizedOperand, '#optimizable?' do
  subject { object.optimizable? }

  let(:header)    { Relation::Header.coerce([[:id, Integer], [:name, String]])          }
  let(:base)      { Relation.new(header, LazyEnumerable.new([[1, 'Dan Kubb']]))         }
  let(:attribute) { Attribute::Object.new(:test)                                        }
  let(:relation)  { operand.summarize(summarize_per) { |r| r.add(attribute, function) } }
  let(:object)    { described_class.new(relation)                                       }

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

  context 'when the operand is optimizable' do
    let(:operand)       { base.rename({})       }
    let(:summarize_per) { TABLE_DEE             }
    let(:function)      { Aggregate::Sum.new(1) }

    it { should be(true) }
  end

  context 'when summarize_per is optimizable' do
    let(:operand)       { base                  }
    let(:summarize_per) { TABLE_DEE.rename({})  }
    let(:function)      { Aggregate::Sum.new(1) }

    it { should be(true) }
  end

  context 'when summarizers are optimizable' do
    let(:operand)       { base                                                   }
    let(:summarize_per) { TABLE_DEE.rename({})                                   }
    let(:function)      { Aggregate::Sum.new(Function::Numeric::Absolute.new(1)) }

    it { should be(true) }
  end

  context 'when the operand, summarize_per and summarizers are not optimizable' do
    let(:operand)       { base                  }
    let(:summarize_per) { TABLE_DEE             }
    let(:function)      { Aggregate::Sum.new(1) }

    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/summarization/unoptimized_operand/optimizable_predicate_spec.rb
axiom-optimizer-0.1.1 spec/unit/axiom/optimizer/algebra/summarization/unoptimized_operand/optimizable_predicate_spec.rb