Sha256: 76071cd97279ca6c5cc8884946b43bacf0b9bffc4e7a9026c7a2a6e2030c8571

Contents?: true

Size: 1.79 KB

Versions: 6

Compression:

Stored size: 1.79 KB

Contents

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

describe "prepared_statements_with_pk plugin" do
  before do
    deprecated do
      @db = Sequel.mock(:fetch=>{:id=>1, :name=>'foo', :i=>2}, :autoid=>proc{|sql| 1}, :numrows=>1, :servers=>{:read_only=>{}})
      @c = Class.new(Sequel::Model(@db[:people]))
      @c.columns :id, :name, :i
      @c.plugin :prepared_statements_with_pk
      @p = @c.load(:id=>1, :name=>'foo', :i=>2)
      @db.sqls
    end
  end

  deprecated "should load the prepared_statements plugin" do
    @c.plugins.must_include(Sequel::Plugins::PreparedStatements)
  end

  deprecated "should correctly lookup by primary key from dataset" do
    @c.dataset.filter(:name=>'foo')[1].must_equal @p
    @c.db.sqls.must_equal ["SELECT * FROM people WHERE ((name = 'foo') AND (people.id = 1)) LIMIT 1 -- read_only"]
  end

  deprecated "should still work correctly if there are multiple conflicting variables" do
    @c.dataset.filter(:name=>'foo').or(:name=>'bar')[1].must_equal @p
    @c.db.sqls.must_equal ["SELECT * FROM people WHERE (((name = 'foo') OR (name = 'bar')) AND (people.id = 1)) LIMIT 1 -- read_only"]
  end

  deprecated "should still work correctly if the primary key is used elsewhere in the query" do
    @c.dataset.filter{id > 2}[1].must_equal @p
    @c.db.sqls.must_equal ["SELECT * FROM people WHERE ((id > 2) AND (people.id = 1)) LIMIT 1 -- read_only"]
  end

  deprecated "should respect explicitly set server" do
    @c.dataset.filter(:name=>'foo')[1].must_equal @p
    @c.db.sqls.must_equal ["SELECT * FROM people WHERE ((name = 'foo') AND (people.id = 1)) LIMIT 1 -- read_only"]
    @c.dataset.server(:default).filter(:name=>'foo')[1].must_equal @p
    @c.db.sqls.must_equal ["SELECT * FROM people WHERE ((name = 'foo') AND (people.id = 1)) LIMIT 1"]
  end
end

Version data entries

6 entries across 6 versions & 2 rubygems

Version Path
sequel-4.49.0 spec/extensions/prepared_statements_with_pk_spec.rb
sequel-4.48.0 spec/extensions/prepared_statements_with_pk_spec.rb
tdiary-5.0.5 vendor/bundle/gems/sequel-4.47.0/spec/extensions/prepared_statements_with_pk_spec.rb
sequel-4.47.0 spec/extensions/prepared_statements_with_pk_spec.rb
sequel-4.46.0 spec/extensions/prepared_statements_with_pk_spec.rb
sequel-4.45.0 spec/extensions/prepared_statements_with_pk_spec.rb