From 71a4158fd0494e47e52ec701f7d40f5ae068f811 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Sun, 11 Apr 2010 13:20:02 +0000 Subject: [PATCH] Fixes calculation of version estimated hours with subtasks (#5265). git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3633 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/models/version.rb | 3 ++- test/unit/version_test.rb | 28 ++++++++++++++++++++++++++++ 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/app/models/version.rb b/app/models/version.rb index bc0e17e2..f9b48fb1 100644 --- a/app/models/version.rb +++ b/app/models/version.rb @@ -52,8 +52,9 @@ class Version < ActiveRecord::Base end # Returns the total estimated time for this version + # (sum of leaves estimated_hours) def estimated_hours - @estimated_hours ||= fixed_issues.sum(:estimated_hours).to_f + @estimated_hours ||= fixed_issues.leaves.sum(:estimated_hours).to_f end # Returns the total reported time for this version diff --git a/test/unit/version_test.rb b/test/unit/version_test.rb index dcc1edbc..1abb4a27 100644 --- a/test/unit/version_test.rb +++ b/test/unit/version_test.rb @@ -104,6 +104,34 @@ class VersionTest < ActiveSupport::TestCase assert_progress_equal (25.0*0.2 + 25.0*1 + 10.0*0.3 + 40.0*0.1)/100.0*100, v.completed_pourcent assert_progress_equal 25.0/100.0*100, v.closed_pourcent end + + context "#estimated_hours" do + setup do + @version = Version.create!(:project_id => 1, :name => '#estimated_hours') + end + + should "return 0 with no assigned issues" do + assert_equal 0, @version.estimated_hours + end + + should "return 0 with no estimated hours" do + add_issue(@version) + assert_equal 0, @version.estimated_hours + end + + should "return the sum of estimated hours" do + add_issue(@version, :estimated_hours => 2.5) + add_issue(@version, :estimated_hours => 5) + assert_equal 7.5, @version.estimated_hours + end + + should "return the sum of leaves estimated hours" do + parent = add_issue(@version) + add_issue(@version, :estimated_hours => 2.5, :parent_issue_id => parent.id) + add_issue(@version, :estimated_hours => 5, :parent_issue_id => parent.id) + assert_equal 7.5, @version.estimated_hours + end + end test "should update all issue's fixed_version associations in case the hierarchy changed XXX" do User.current = User.find(1) # Need the admin's permissions