Sha256: 45872006638bd19e6cddcd6bbd34bf2f4d6968115e116a22dbe3c254115b8b89

Contents?: true

Size: 1.42 KB

Versions: 34

Compression:

Stored size: 1.42 KB

Contents

require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")

describe "Dataset#select_remove" do
  before do
    @d = Sequel.mock.from(:test).extension(:select_remove)
    @d.columns :a, :b, :c
  end
  
  it "should remove columns from the selected columns" do
    @d.sql.must_equal 'SELECT * FROM test'
    @d.select_remove(:a).sql.must_equal 'SELECT b, c FROM test'
    @d.select_remove(:b).sql.must_equal 'SELECT a, c FROM test'
    @d.select_remove(:c).sql.must_equal 'SELECT a, b FROM test'
  end

  it "should work correctly if there are already columns selected" do
    d = @d.select(:a, :b, :c)
    d.columns :a, :b, :c
    d.select_remove(:c).sql.must_equal 'SELECT a, b FROM test'
  end

  it "should have no effect if the columns given are not currently selected" do
    @d.select_remove(:d).sql.must_equal 'SELECT a, b, c FROM test'
  end

  it "should handle expressions where Sequel can't determine the alias by itself" do
    d = @d.select(:a, Sequel.function(:b), Sequel.as(:c, :b))
    d.columns :a, :"b()", :b
    d.select_remove(:"b()").sql.must_equal 'SELECT a, c AS b FROM test'
  end

  it "should remove expressions if given exact expressions" do
    d = @d.select(:a, Sequel.function(:b), Sequel.as(:c, :b))
    d.columns :a, :"b()", :b
    d.select_remove(Sequel.function(:b)).sql.must_equal 'SELECT a, c AS b FROM test'
    d.select_remove(Sequel.as(:c, :b)).sql.must_equal 'SELECT a, b() FROM test'
  end
end

Version data entries

34 entries across 32 versions & 2 rubygems

Version Path
sequel-4.49.0 spec/extensions/select_remove_spec.rb
sequel-4.48.0 spec/extensions/select_remove_spec.rb
tdiary-5.0.5 vendor/bundle/gems/sequel-4.47.0/spec/extensions/select_remove_spec.rb
tdiary-5.0.5 vendor/bundle/gems/sequel-4.44.0/spec/extensions/select_remove_spec.rb
tdiary-5.0.5 vendor/bundle/gems/tdiary-5.0.4/vendor/bundle/gems/sequel-4.44.0/spec/extensions/select_remove_spec.rb
sequel-4.47.0 spec/extensions/select_remove_spec.rb
sequel-4.46.0 spec/extensions/select_remove_spec.rb
sequel-4.45.0 spec/extensions/select_remove_spec.rb
tdiary-5.0.4 vendor/bundle/gems/sequel-4.44.0/spec/extensions/select_remove_spec.rb
sequel-4.44.0 spec/extensions/select_remove_spec.rb
sequel-4.43.0 spec/extensions/select_remove_spec.rb
sequel-4.42.1 spec/extensions/select_remove_spec.rb
sequel-4.42.0 spec/extensions/select_remove_spec.rb
sequel-4.41.0 spec/extensions/select_remove_spec.rb
sequel-4.40.0 spec/extensions/select_remove_spec.rb
sequel-4.39.0 spec/extensions/select_remove_spec.rb
tdiary-5.0.2 vendor/bundle/gems/sequel-4.37.0/spec/extensions/select_remove_spec.rb
sequel-4.38.0 spec/extensions/select_remove_spec.rb
sequel-4.37.0 spec/extensions/select_remove_spec.rb
sequel-4.36.0 spec/extensions/select_remove_spec.rb