Permalink
Browse files

Merge pull request #9397 from senny/9201_duplicate_associations_with_…

…natural_key

test case to prevent duplicated associations with custom PK.
  • Loading branch information...
rafaelfranca committed Feb 24, 2013
2 parents fb40358 + 96c1caf commit 83a9efb8292dcea15defc5c913b66e2c456937c0
@@ -20,6 +20,8 @@
require 'models/bulb'
require 'models/engine'
require 'models/categorization'
+require 'models/minivan'
+require 'models/speedometer'
class HasManyAssociationsTestForCountWithFinderSql < ActiveRecord::TestCase
class Invoice < ActiveRecord::Base
@@ -1747,4 +1749,12 @@ def test_collection_association_with_private_kernel_method
david.posts_with_special_categorizations = []
assert_equal [], david.posts_with_special_categorizations
end
+
+ test "does not duplicate associations when used with natural primary keys" do
+ speedometer = Speedometer.create!(id: '4')
+ minivan = speedometer.minivans.create!(minivan_id: 'a-van-red' ,name: 'a van', color: 'red')
+
+ assert_equal 1, speedometer.minivans.to_a.size, "Only one association should be present:\n#{speedometer.minivans.to_a}"
+ assert_equal 1, speedometer.reload.minivans.to_a.size
+ end
end
@@ -1,4 +1,6 @@
class Speedometer < ActiveRecord::Base
self.primary_key = :speedometer_id
belongs_to :dashboard
+
+ has_many :minivans
end

0 comments on commit 83a9efb

Please sign in to comment.