@@ -1026,7 +1026,7 module ApplicationHelper | |||||
1026 | (pcts[1] > 0 ? content_tag('td', '', :style => "width: #{pcts[1]}%;", :class => 'done') : ''.html_safe) + |
|
1026 | (pcts[1] > 0 ? content_tag('td', '', :style => "width: #{pcts[1]}%;", :class => 'done') : ''.html_safe) + | |
1027 | (pcts[2] > 0 ? content_tag('td', '', :style => "width: #{pcts[2]}%;", :class => 'todo') : ''.html_safe) |
|
1027 | (pcts[2] > 0 ? content_tag('td', '', :style => "width: #{pcts[2]}%;", :class => 'todo') : ''.html_safe) | |
1028 | ), :class => 'progress', :style => "width: #{width};").html_safe + |
|
1028 | ), :class => 'progress', :style => "width: #{width};").html_safe + | |
1029 |
content_tag('p', legend, :class => 'p |
|
1029 | content_tag('p', legend, :class => 'percent').html_safe | |
1030 | end |
|
1030 | end | |
1031 |
|
1031 | |||
1032 | def checked_image(checked=true) |
|
1032 | def checked_image(checked=true) |
@@ -567,7 +567,7 class Project < ActiveRecord::Base | |||||
567 | total / self_and_descendants.count |
|
567 | total / self_and_descendants.count | |
568 | else |
|
568 | else | |
569 | if versions.count > 0 |
|
569 | if versions.count > 0 | |
570 |
total = versions.collect(&:completed_p |
|
570 | total = versions.collect(&:completed_percent).sum | |
571 |
|
571 | |||
572 | total / versions.count |
|
572 | total / versions.count | |
573 | else |
|
573 | else |
@@ -97,10 +97,10 class Version < ActiveRecord::Base | |||||
97 | end |
|
97 | end | |
98 |
|
98 | |||
99 | def behind_schedule? |
|
99 | def behind_schedule? | |
100 |
if completed_p |
|
100 | if completed_percent == 100 | |
101 | return false |
|
101 | return false | |
102 | elsif due_date && start_date |
|
102 | elsif due_date && start_date | |
103 |
done_date = start_date + ((due_date - start_date+1)* completed_p |
|
103 | done_date = start_date + ((due_date - start_date+1)* completed_percent/100).floor | |
104 | return done_date <= Date.today |
|
104 | return done_date <= Date.today | |
105 | else |
|
105 | else | |
106 | false # No issues so it's not late |
|
106 | false # No issues so it's not late | |
@@ -109,7 +109,7 class Version < ActiveRecord::Base | |||||
109 |
|
109 | |||
110 | # Returns the completion percentage of this version based on the amount of open/closed issues |
|
110 | # Returns the completion percentage of this version based on the amount of open/closed issues | |
111 | # and the time spent on the open issues. |
|
111 | # and the time spent on the open issues. | |
112 |
def completed_p |
|
112 | def completed_percent | |
113 | if issues_count == 0 |
|
113 | if issues_count == 0 | |
114 | 0 |
|
114 | 0 | |
115 | elsif open_issues_count == 0 |
|
115 | elsif open_issues_count == 0 | |
@@ -119,8 +119,14 class Version < ActiveRecord::Base | |||||
119 | end |
|
119 | end | |
120 | end |
|
120 | end | |
121 |
|
121 | |||
|
122 | # TODO: remove in Redmine 3.0 | |||
|
123 | def completed_pourcent | |||
|
124 | ActiveSupport::Deprecation.warn "Version#completed_pourcent is deprecated and will be removed in Redmine 3.0. Please use #completed_percent instead." | |||
|
125 | completed_percent | |||
|
126 | end | |||
|
127 | ||||
122 | # Returns the percentage of issues that have been marked as 'closed'. |
|
128 | # Returns the percentage of issues that have been marked as 'closed'. | |
123 |
def closed_p |
|
129 | def closed_percent | |
124 | if issues_count == 0 |
|
130 | if issues_count == 0 | |
125 | 0 |
|
131 | 0 | |
126 | else |
|
132 | else | |
@@ -128,6 +134,12 class Version < ActiveRecord::Base | |||||
128 | end |
|
134 | end | |
129 | end |
|
135 | end | |
130 |
|
136 | |||
|
137 | # TODO: remove in Redmine 3.0 | |||
|
138 | def closed_pourcent | |||
|
139 | ActiveSupport::Deprecation.warn "Version#closed_pourcent is deprecated and will be removed in Redmine 3.0. Please use #closed_percent instead." | |||
|
140 | closed_percent | |||
|
141 | end | |||
|
142 | ||||
131 | # Returns true if the version is overdue: due date reached and some open issues |
|
143 | # Returns true if the version is overdue: due date reached and some open issues | |
132 | def overdue? |
|
144 | def overdue? | |
133 | effective_date && (effective_date < Date.today) && (open_issues_count > 0) |
|
145 | effective_date && (effective_date < Date.today) && (open_issues_count > 0) |
@@ -16,7 +16,7 | |||||
16 | <% end %> |
|
16 | <% end %> | |
17 |
|
17 | |||
18 | <% if version.issues_count > 0 %> |
|
18 | <% if version.issues_count > 0 %> | |
19 |
<%= progress_bar([version.closed_p |
|
19 | <%= progress_bar([version.closed_percent, version.completed_percent], :width => '40em', :legend => ('%0.0f%' % version.completed_percent)) %> | |
20 | <p class="progress-info"> |
|
20 | <p class="progress-info"> | |
21 | <%= link_to(l(:label_x_issues, :count => version.issues_count), |
|
21 | <%= link_to(l(:label_x_issues, :count => version.issues_count), | |
22 | project_issues_path(version.project, :status_id => '*', :fixed_version_id => version, :set_filter => 1)) %> |
|
22 | project_issues_path(version.project, :status_id => '*', :fixed_version_id => version, :set_filter => 1)) %> |
@@ -307,9 +307,9 module Redmine | |||||
307 | options[:zoom] ||= 1 |
|
307 | options[:zoom] ||= 1 | |
308 | options[:g_width] ||= (self.date_to - self.date_from + 1) * options[:zoom] |
|
308 | options[:g_width] ||= (self.date_to - self.date_from + 1) * options[:zoom] | |
309 | coords = coordinates(version.start_date, |
|
309 | coords = coordinates(version.start_date, | |
310 |
version.due_date, version.completed_p |
|
310 | version.due_date, version.completed_percent, | |
311 | options[:zoom]) |
|
311 | options[:zoom]) | |
312 |
label = "#{h version} #{h version.completed_p |
|
312 | label = "#{h version} #{h version.completed_percent.to_i.to_s}%" | |
313 | label = h("#{version.project} -") + label unless @project && @project == version.project |
|
313 | label = h("#{version.project} -") + label unless @project && @project == version.project | |
314 | case options[:format] |
|
314 | case options[:format] | |
315 | when :html |
|
315 | when :html |
@@ -702,7 +702,7 table.progress td { height: 1em; } | |||||
702 | table.progress td.closed { background: #BAE0BA none repeat scroll 0%; } |
|
702 | table.progress td.closed { background: #BAE0BA none repeat scroll 0%; } | |
703 | table.progress td.done { background: #D3EDD3 none repeat scroll 0%; } |
|
703 | table.progress td.done { background: #D3EDD3 none repeat scroll 0%; } | |
704 | table.progress td.todo { background: #eee none repeat scroll 0%; } |
|
704 | table.progress td.todo { background: #eee none repeat scroll 0%; } | |
705 |
p.p |
|
705 | p.percent {font-size: 80%;} | |
706 | p.progress-info {clear: left; font-size: 80%; margin-top:-4px; color:#777;} |
|
706 | p.progress-info {clear: left; font-size: 80%; margin-top:-4px; color:#777;} | |
707 |
|
707 | |||
708 | #roadmap table.progress td { height: 1.2em; } |
|
708 | #roadmap table.progress td { height: 1.2em; } |
@@ -46,8 +46,8 class VersionTest < ActiveSupport::TestCase | |||||
46 | def test_progress_should_be_0_with_no_assigned_issues |
|
46 | def test_progress_should_be_0_with_no_assigned_issues | |
47 | project = Project.find(1) |
|
47 | project = Project.find(1) | |
48 | v = Version.create!(:project => project, :name => 'Progress') |
|
48 | v = Version.create!(:project => project, :name => 'Progress') | |
49 |
assert_equal 0, v.completed_p |
|
49 | assert_equal 0, v.completed_percent | |
50 |
assert_equal 0, v.closed_p |
|
50 | assert_equal 0, v.closed_percent | |
51 | end |
|
51 | end | |
52 |
|
52 | |||
53 | def test_progress_should_be_0_with_unbegun_assigned_issues |
|
53 | def test_progress_should_be_0_with_unbegun_assigned_issues | |
@@ -55,8 +55,8 class VersionTest < ActiveSupport::TestCase | |||||
55 | v = Version.create!(:project => project, :name => 'Progress') |
|
55 | v = Version.create!(:project => project, :name => 'Progress') | |
56 | add_issue(v) |
|
56 | add_issue(v) | |
57 | add_issue(v, :done_ratio => 0) |
|
57 | add_issue(v, :done_ratio => 0) | |
58 |
assert_progress_equal 0, v.completed_p |
|
58 | assert_progress_equal 0, v.completed_percent | |
59 |
assert_progress_equal 0, v.closed_p |
|
59 | assert_progress_equal 0, v.closed_percent | |
60 | end |
|
60 | end | |
61 |
|
61 | |||
62 | def test_progress_should_be_100_with_closed_assigned_issues |
|
62 | def test_progress_should_be_100_with_closed_assigned_issues | |
@@ -67,8 +67,8 class VersionTest < ActiveSupport::TestCase | |||||
67 | add_issue(v, :status => status, :done_ratio => 20) |
|
67 | add_issue(v, :status => status, :done_ratio => 20) | |
68 | add_issue(v, :status => status, :done_ratio => 70, :estimated_hours => 25) |
|
68 | add_issue(v, :status => status, :done_ratio => 70, :estimated_hours => 25) | |
69 | add_issue(v, :status => status, :estimated_hours => 15) |
|
69 | add_issue(v, :status => status, :estimated_hours => 15) | |
70 |
assert_progress_equal 100.0, v.completed_p |
|
70 | assert_progress_equal 100.0, v.completed_percent | |
71 |
assert_progress_equal 100.0, v.closed_p |
|
71 | assert_progress_equal 100.0, v.closed_percent | |
72 | end |
|
72 | end | |
73 |
|
73 | |||
74 | def test_progress_should_consider_done_ratio_of_open_assigned_issues |
|
74 | def test_progress_should_consider_done_ratio_of_open_assigned_issues | |
@@ -77,8 +77,8 class VersionTest < ActiveSupport::TestCase | |||||
77 | add_issue(v) |
|
77 | add_issue(v) | |
78 | add_issue(v, :done_ratio => 20) |
|
78 | add_issue(v, :done_ratio => 20) | |
79 | add_issue(v, :done_ratio => 70) |
|
79 | add_issue(v, :done_ratio => 70) | |
80 |
assert_progress_equal (0.0 + 20.0 + 70.0)/3, v.completed_p |
|
80 | assert_progress_equal (0.0 + 20.0 + 70.0)/3, v.completed_percent | |
81 |
assert_progress_equal 0, v.closed_p |
|
81 | assert_progress_equal 0, v.closed_percent | |
82 | end |
|
82 | end | |
83 |
|
83 | |||
84 | def test_progress_should_consider_closed_issues_as_completed |
|
84 | def test_progress_should_consider_closed_issues_as_completed | |
@@ -87,8 +87,8 class VersionTest < ActiveSupport::TestCase | |||||
87 | add_issue(v) |
|
87 | add_issue(v) | |
88 | add_issue(v, :done_ratio => 20) |
|
88 | add_issue(v, :done_ratio => 20) | |
89 | add_issue(v, :status => IssueStatus.where(:is_closed => true).first) |
|
89 | add_issue(v, :status => IssueStatus.where(:is_closed => true).first) | |
90 |
assert_progress_equal (0.0 + 20.0 + 100.0)/3, v.completed_p |
|
90 | assert_progress_equal (0.0 + 20.0 + 100.0)/3, v.completed_percent | |
91 |
assert_progress_equal (100.0)/3, v.closed_p |
|
91 | assert_progress_equal (100.0)/3, v.closed_percent | |
92 | end |
|
92 | end | |
93 |
|
93 | |||
94 | def test_progress_should_consider_estimated_hours_to_weigth_issues |
|
94 | def test_progress_should_consider_estimated_hours_to_weigth_issues | |
@@ -98,8 +98,8 class VersionTest < ActiveSupport::TestCase | |||||
98 | add_issue(v, :estimated_hours => 20, :done_ratio => 30) |
|
98 | add_issue(v, :estimated_hours => 20, :done_ratio => 30) | |
99 | add_issue(v, :estimated_hours => 40, :done_ratio => 10) |
|
99 | add_issue(v, :estimated_hours => 40, :done_ratio => 10) | |
100 | add_issue(v, :estimated_hours => 25, :status => IssueStatus.where(:is_closed => true).first) |
|
100 | add_issue(v, :estimated_hours => 25, :status => IssueStatus.where(:is_closed => true).first) | |
101 |
assert_progress_equal (10.0*0 + 20.0*0.3 + 40*0.1 + 25.0*1)/95.0*100, v.completed_p |
|
101 | assert_progress_equal (10.0*0 + 20.0*0.3 + 40*0.1 + 25.0*1)/95.0*100, v.completed_percent | |
102 |
assert_progress_equal 25.0/95.0*100, v.closed_p |
|
102 | assert_progress_equal 25.0/95.0*100, v.closed_percent | |
103 | end |
|
103 | end | |
104 |
|
104 | |||
105 | def test_progress_should_consider_average_estimated_hours_to_weigth_unestimated_issues |
|
105 | def test_progress_should_consider_average_estimated_hours_to_weigth_unestimated_issues | |
@@ -109,8 +109,8 class VersionTest < ActiveSupport::TestCase | |||||
109 | add_issue(v, :status => IssueStatus.where(:is_closed => true).first) |
|
109 | add_issue(v, :status => IssueStatus.where(:is_closed => true).first) | |
110 | add_issue(v, :estimated_hours => 10, :done_ratio => 30) |
|
110 | add_issue(v, :estimated_hours => 10, :done_ratio => 30) | |
111 | add_issue(v, :estimated_hours => 40, :done_ratio => 10) |
|
111 | add_issue(v, :estimated_hours => 40, :done_ratio => 10) | |
112 |
assert_progress_equal (25.0*0.2 + 25.0*1 + 10.0*0.3 + 40.0*0.1)/100.0*100, v.completed_p |
|
112 | assert_progress_equal (25.0*0.2 + 25.0*1 + 10.0*0.3 + 40.0*0.1)/100.0*100, v.completed_percent | |
113 |
assert_progress_equal 25.0/100.0*100, v.closed_p |
|
113 | assert_progress_equal 25.0/100.0*100, v.closed_percent | |
114 | end |
|
114 | end | |
115 |
|
115 | |||
116 | def test_should_sort_scheduled_then_unscheduled_versions |
|
116 | def test_should_sort_scheduled_then_unscheduled_versions | |
@@ -152,7 +152,7 class VersionTest < ActiveSupport::TestCase | |||||
152 | @version.update_attribute(:effective_date, 7.days.from_now.to_date) |
|
152 | @version.update_attribute(:effective_date, 7.days.from_now.to_date) | |
153 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left |
|
153 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left | |
154 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left |
|
154 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left | |
155 |
assert_equal 60, @version.completed_p |
|
155 | assert_equal 60, @version.completed_percent | |
156 | assert_equal false, @version.behind_schedule? |
|
156 | assert_equal false, @version.behind_schedule? | |
157 | end |
|
157 | end | |
158 |
|
158 | |||
@@ -160,7 +160,7 class VersionTest < ActiveSupport::TestCase | |||||
160 | @version.update_attribute(:effective_date, 7.days.from_now.to_date) |
|
160 | @version.update_attribute(:effective_date, 7.days.from_now.to_date) | |
161 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left |
|
161 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left | |
162 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 20) # 14 day span, 20% done, 50% time left |
|
162 | add_issue(@version, :start_date => 7.days.ago, :done_ratio => 20) # 14 day span, 20% done, 50% time left | |
163 |
assert_equal 40, @version.completed_p |
|
163 | assert_equal 40, @version.completed_percent | |
164 | assert_equal true, @version.behind_schedule? |
|
164 | assert_equal true, @version.behind_schedule? | |
165 | end |
|
165 | end | |
166 |
|
166 | |||
@@ -168,7 +168,7 class VersionTest < ActiveSupport::TestCase | |||||
168 | @version.update_attribute(:effective_date, 7.days.from_now.to_date) |
|
168 | @version.update_attribute(:effective_date, 7.days.from_now.to_date) | |
169 | add_issue(@version, :start_date => 14.days.ago, :done_ratio => 100, :status => IssueStatus.find(5)) # 7 day span |
|
169 | add_issue(@version, :start_date => 14.days.ago, :done_ratio => 100, :status => IssueStatus.find(5)) # 7 day span | |
170 | add_issue(@version, :start_date => 14.days.ago, :done_ratio => 100, :status => IssueStatus.find(5)) # 7 day span |
|
170 | add_issue(@version, :start_date => 14.days.ago, :done_ratio => 100, :status => IssueStatus.find(5)) # 7 day span | |
171 |
assert_equal 100, @version.completed_p |
|
171 | assert_equal 100, @version.completed_percent | |
172 | assert_equal false, @version.behind_schedule? |
|
172 | assert_equal false, @version.behind_schedule? | |
173 | end |
|
173 | end | |
174 | end |
|
174 | end |
General Comments 0
You need to be logged in to leave comments.
Login now