Sha256: 1492bc6db8f8ae6ec634836e63eeff328f9ca168e13c72326b66f4d3953928c8

Contents?: true

Size: 1.21 KB

Versions: 8

Compression:

Stored size: 1.21 KB

Contents

require File.expand_path("helper", File.dirname(__FILE__))

class FindSomeTest < ActiveSupport::TestCase
  fixtures :blogs, :posts

  should "cache find(id, id) calls" do
    post1 = Post.first
    post2 = Post.last

    assert_nil(Kasket.cache.read(post1.kasket_key))
    assert_nil(Kasket.cache.read(post2.kasket_key))

    Post.find(post1.id, post2.id)

    assert(Kasket.cache.read(post1.kasket_key))
    assert(Kasket.cache.read(post2.kasket_key))
    Post.connection.expects(:select_all).never
    Post.find(post1.id, post2.id)
  end

  should "only lookup the records that are not in the cache" do
    post1 = Post.first
    post2 = Post.last
    assert_equal(post1, Post.find(post1.id))
    assert(Kasket.cache.read(post1.kasket_key))
    assert_nil(Kasket.cache.read(post2.kasket_key))

    Post.expects(:find_by_sql_without_kasket).with("SELECT * FROM \"posts\" WHERE (\"posts\".\"id\" = #{post2.id}) ").returns([post2])
    found_posts = Post.find(post1.id, post2.id)
    assert_equal([post1, post2].map(&:id).sort, found_posts.map(&:id).sort)

    Post.expects(:find_by_sql_without_kasket).never
    found_posts = Post.find(post1.id, post2.id)
    assert_equal([post1, post2].map(&:id).sort, found_posts.map(&:id).sort)
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
kasket-1.0.3 test/find_some_test.rb
kasket-1.0.3.beta2 test/find_some_test.rb
kasket-1.0.3.beta1 test/find_some_test.rb
kasket-1.0.2 test/find_some_test.rb
kasket-1.0.1 test/find_some_test.rb
kasket-1.0.0 test/find_some_test.rb
kasket-0.9.1 test/find_some_test.rb
kasket-0.9.0 test/find_some_test.rb