diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2015-10-09 09:02:11 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2015-10-09 09:02:11 +0000 |
commit | 498a429a41bc47fc7e3980926901cc60863afe9a (patch) | |
tree | b72a844dd383e35a87562d6278134737a8f660ee /test/unit/query_test.rb | |
parent | 3a3fe668c77cdb3266bfd1b067a30a1c09713763 (diff) | |
download | redmine-498a429a41bc47fc7e3980926901cc60863afe9a.tar.gz redmine-498a429a41bc47fc7e3980926901cc60863afe9a.zip |
Display totals for each group on grouped queries (#1561).
git-svn-id: http://svn.redmine.org/redmine/trunk@14665 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/unit/query_test.rb')
-rw-r--r-- | test/unit/query_test.rb | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/test/unit/query_test.rb b/test/unit/query_test.rb index b69bec740..679fc772d 100644 --- a/test/unit/query_test.rb +++ b/test/unit/query_test.rb @@ -1183,6 +1183,19 @@ class QueryTest < ActiveSupport::TestCase assert_equal 6.6, q.total_for(:estimated_hours) end + def test_total_by_group_for_estimated_hours + Issue.delete_all + Issue.generate!(:estimated_hours => 5.5, :assigned_to_id => 2) + Issue.generate!(:estimated_hours => 1.1, :assigned_to_id => 3) + Issue.generate!(:estimated_hours => 3.5) + + q = IssueQuery.new(:group_by => 'assigned_to') + assert_equal( + {nil => 3.5, User.find(2) => 5.5, User.find(3) => 1.1}, + q.total_by_group_for(:estimated_hours) + ) + end + def test_total_for_spent_hours TimeEntry.delete_all TimeEntry.generate!(:hours => 5.5) @@ -1192,6 +1205,20 @@ class QueryTest < ActiveSupport::TestCase assert_equal 6.6, q.total_for(:spent_hours) end + def test_total_by_group_for_spent_hours + TimeEntry.delete_all + TimeEntry.generate!(:hours => 5.5, :issue_id => 1) + TimeEntry.generate!(:hours => 1.1, :issue_id => 2) + Issue.where(:id => 1).update_all(:assigned_to_id => 2) + Issue.where(:id => 2).update_all(:assigned_to_id => 3) + + q = IssueQuery.new(:group_by => 'assigned_to') + assert_equal( + {User.find(2) => 5.5, User.find(3) => 1.1}, + q.total_by_group_for(:spent_hours) + ) + end + def test_total_for_int_custom_field field = IssueCustomField.generate!(:field_format => 'int', :is_for_all => true) CustomValue.create!(:customized => Issue.find(1), :custom_field => field, :value => '2') @@ -1202,6 +1229,20 @@ class QueryTest < ActiveSupport::TestCase assert_equal 9, q.total_for("cf_#{field.id}") end + def test_total_by_group_for_int_custom_field + field = IssueCustomField.generate!(:field_format => 'int', :is_for_all => true) + CustomValue.create!(:customized => Issue.find(1), :custom_field => field, :value => '2') + CustomValue.create!(:customized => Issue.find(2), :custom_field => field, :value => '7') + Issue.where(:id => 1).update_all(:assigned_to_id => 2) + Issue.where(:id => 2).update_all(:assigned_to_id => 3) + + q = IssueQuery.new(:group_by => 'assigned_to') + assert_equal( + {User.find(2) => 2, User.find(3) => 7}, + q.total_by_group_for("cf_#{field.id}") + ) + end + def test_total_for_float_custom_field field = IssueCustomField.generate!(:field_format => 'float', :is_for_all => true) CustomValue.create!(:customized => Issue.find(1), :custom_field => field, :value => '2.3') |