diff options
author | Sean Griffin <sean@thoughtbot.com> | 2014-12-11 13:34:46 -0700 |
---|---|---|
committer | Sean Griffin <sean@thoughtbot.com> | 2014-12-11 13:34:46 -0700 |
commit | 39542fba54328ca048fb75a5d5b37f8e1d4c1f37 (patch) | |
tree | 1d41414fe6b6208e075ce6016d8ef03f3c7cd00f /activerecord/test | |
parent | 387065a023b3883576a581af79b0a202bdcc07a8 (diff) | |
download | rails-39542fba54328ca048fb75a5d5b37f8e1d4c1f37.tar.gz rails-39542fba54328ca048fb75a5d5b37f8e1d4c1f37.tar.bz2 rails-39542fba54328ca048fb75a5d5b37f8e1d4c1f37.zip |
Improve the test case introduced by bd0d47e
Diffstat (limited to 'activerecord/test')
-rw-r--r-- | activerecord/test/cases/calculations_test.rb | 29 |
1 files changed, 10 insertions, 19 deletions
diff --git a/activerecord/test/cases/calculations_test.rb b/activerecord/test/cases/calculations_test.rb index 1264251418..6cf18bc3c6 100644 --- a/activerecord/test/cases/calculations_test.rb +++ b/activerecord/test/cases/calculations_test.rb @@ -612,25 +612,16 @@ class CalculationsTest < ActiveRecord::TestCase end def test_calculation_with_polymorphic_relation - sp = ShipPart.create! name: "no trinket" - sp_with_trinket = ShipPart.create! name: "has_trinket" - sp_with_trinket.trinkets.create! - ship_parts = [sp.id,sp_with_trinket.id] - - sp_with_trinket_relation = ShipPart.where(id:ship_parts).joins(:trinkets) - sp_with_trinket_relation2 = sp_with_trinket_relation.where(name:"has_trinket") - sp_with_trinket_relation3 = sp_with_trinket_relation.where(treasures: {looter_type:"ShipPart"}) - sp_with_trinket_relation4 = ShipPart.where(id:ship_parts).eager_load(:trinkets).where.not(treasures:{id:nil}) - - [sp_with_trinket_relation,sp_with_trinket_relation2, - sp_with_trinket_relation3,sp_with_trinket_relation4].each do |with_trinket_rel| - assert_equal 1, with_trinket_rel.count - assert_equal [sp_with_trinket.id], with_trinket_rel.pluck(:id) - assert_equal sp_with_trinket.id, with_trinket_rel.sum(:id) - assert_equal ({"has_trinket" => sp_with_trinket.id}), with_trinket_rel.group('ship_parts.name').sum(:id) - assert_equal ({"has_trinket" => sp_with_trinket.id}), with_trinket_rel.where(id:sp_with_trinket.id). - group('ship_parts.name').sum(:id) - end + part = ShipPart.create!(name: "has trinket") + part.trinkets.create! + + assert_equal part.id, ShipPart.joins(:trinkets).sum(:id) end + def test_grouped_calculation_with_polymorphic_relation + part = ShipPart.create!(name: "has trinket") + part.trinkets.create! + + assert_equal({ "has trinket" => part.id }, ShipPart.joins(:trinkets).group("ship_parts.name").sum(:id)) + end end |