Sha256: aca4d2e0a81a1d0f1e1cea9c93726ec20413fd0b9f864adbd3ae0b056e61fe33

Contents?: true

Size: 1.74 KB

Versions: 5

Compression:

Stored size: 1.74 KB

Contents

# encoding: utf-8

require 'spec_helper'

describe SQL::Generator::Relation::Set, '#to_s' do
  subject { object.to_s }

  let(:id)            { Attribute::Integer.new(:id)                      }
  let(:name)          { Attribute::String.new(:name)                     }
  let(:age)           { Attribute::Integer.new(:age, :required => false) }
  let(:header)        { [ id, name, age ]                                }
  let(:body)          { [ [ 1, 'Dan Kubb', 35 ] ].each                   }
  let(:base_relation) { Relation::Base.new('users', header, body)        }
  let(:object)        { described_class.new                              }

  context 'when no object visited' do
    it_should_behave_like 'an idempotent method'

    it { should respond_to(:to_s) }

    it { should be_frozen }

    its(:to_s) { should == '' }
  end

  context 'when a difference is visited' do
    before do
      object.visit(base_relation.difference(base_relation))
    end

    it_should_behave_like 'a generated SQL expression'

    its(:to_s) { should eql('(SELECT "id", "name", "age" FROM "users") EXCEPT (SELECT "id", "name", "age" FROM "users")') }
  end

  context 'when an intersection is visited' do
    before do
      object.visit(base_relation.intersect(base_relation))
    end

    it_should_behave_like 'a generated SQL expression'

    its(:to_s) { should eql('(SELECT "id", "name", "age" FROM "users") INTERSECT (SELECT "id", "name", "age" FROM "users")') }
  end

  context 'when a union is visited' do
    before do
      object.visit(base_relation.union(base_relation))
    end

    it_should_behave_like 'a generated SQL expression'

    its(:to_s) { should eql('(SELECT "id", "name", "age" FROM "users") UNION (SELECT "id", "name", "age" FROM "users")') }
  end
end

Version data entries

5 entries across 5 versions & 2 rubygems

Version Path
axiom-sql-generator-0.1.0 spec/unit/axiom/sql/generator/relation/set/to_s_spec.rb
veritas-sql-generator-0.0.7 spec/unit/veritas/sql/generator/relation/set/to_s_spec.rb
veritas-sql-generator-0.0.6 spec/unit/veritas/sql/generator/relation/set/to_s_spec.rb
veritas-sql-generator-0.0.5 spec/unit/veritas/sql/generator/relation/set/to_s_spec.rb
veritas-sql-generator-0.0.4 spec/unit/veritas/sql/generator/relation/set/to_s_spec.rb