aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/associations/habtm_join_table_test.rb
diff options
context:
space:
mode:
Diffstat (limited to 'activerecord/test/cases/associations/habtm_join_table_test.rb')
-rw-r--r--activerecord/test/cases/associations/habtm_join_table_test.rb13
1 files changed, 12 insertions, 1 deletions
diff --git a/activerecord/test/cases/associations/habtm_join_table_test.rb b/activerecord/test/cases/associations/habtm_join_table_test.rb
index 0586df1716..bf3e04c3eb 100644
--- a/activerecord/test/cases/associations/habtm_join_table_test.rb
+++ b/activerecord/test/cases/associations/habtm_join_table_test.rb
@@ -8,7 +8,7 @@ class MyBook < ActiveRecord::Base
has_and_belongs_to_many :my_readers
end
-class JoinTableTest < ActiveRecord::TestCase
+class HabtmJoinTableTest < ActiveRecord::TestCase
def setup
ActiveRecord::Base.connection.create_table :my_books, :force => true do |t|
t.string :name
@@ -42,4 +42,15 @@ class JoinTableTest < ActiveRecord::TestCase
end
end
end
+
+ uses_transaction :test_should_cache_result_of_primary_key_check
+ def test_should_cache_result_of_primary_key_check
+ if ActiveRecord::Base.connection.supports_primary_key?
+ ActiveRecord::Base.connection.stubs(:primary_key).with('my_books_my_readers').returns(false).once
+ weaz = MyReader.create(:name=>'Weaz')
+
+ weaz.my_books << MyBook.create(:name=>'Great Expectations')
+ weaz.my_books << MyBook.create(:name=>'Greater Expectations')
+ end
+ end
end