Patch #12725 ยป change_pourcent_to_percent.diff
app/helpers/application_helper.rb | ||
---|---|---|
1026 | 1026 |
(pcts[1] > 0 ? content_tag('td', '', :style => "width: #{pcts[1]}%;", :class => 'done') : ''.html_safe) + |
1027 | 1027 |
(pcts[2] > 0 ? content_tag('td', '', :style => "width: #{pcts[2]}%;", :class => 'todo') : ''.html_safe) |
1028 | 1028 |
), :class => 'progress', :style => "width: #{width};").html_safe + |
1029 |
content_tag('p', legend, :class => 'pourcent').html_safe
|
|
1029 |
content_tag('p', legend, :class => 'percent').html_safe
|
|
1030 | 1030 |
end |
1031 | 1031 | |
1032 | 1032 |
def checked_image(checked=true) |
app/models/project.rb | ||
---|---|---|
567 | 567 |
total / self_and_descendants.count |
568 | 568 |
else |
569 | 569 |
if versions.count > 0 |
570 |
total = versions.collect(&:completed_pourcent).sum
|
|
570 |
total = versions.collect(&:completed_percent).sum
|
|
571 | 571 | |
572 | 572 |
total / versions.count |
573 | 573 |
else |
app/models/version.rb | ||
---|---|---|
97 | 97 |
end |
98 | 98 | |
99 | 99 |
def behind_schedule? |
100 |
if completed_pourcent == 100
|
|
100 |
if completed_percent == 100
|
|
101 | 101 |
return false |
102 | 102 |
elsif due_date && start_date |
103 |
done_date = start_date + ((due_date - start_date+1)* completed_pourcent/100).floor
|
|
103 |
done_date = start_date + ((due_date - start_date+1)* completed_percent/100).floor
|
|
104 | 104 |
return done_date <= Date.today |
105 | 105 |
else |
106 | 106 |
false # No issues so it's not late |
... | ... | |
109 | 109 | |
110 | 110 |
# Returns the completion percentage of this version based on the amount of open/closed issues |
111 | 111 |
# and the time spent on the open issues. |
112 |
def completed_pourcent
|
|
112 |
def completed_percent
|
|
113 | 113 |
if issues_count == 0 |
114 | 114 |
0 |
115 | 115 |
elsif open_issues_count == 0 |
... | ... | |
120 | 120 |
end |
121 | 121 | |
122 | 122 |
# Returns the percentage of issues that have been marked as 'closed'. |
123 |
def closed_pourcent
|
|
123 |
def closed_percent
|
|
124 | 124 |
if issues_count == 0 |
125 | 125 |
0 |
126 | 126 |
else |
app/views/versions/_overview.html.erb | ||
---|---|---|
16 | 16 |
<% end %> |
17 | 17 | |
18 | 18 |
<% if version.issues_count > 0 %> |
19 |
<%= progress_bar([version.closed_pourcent, version.completed_pourcent], :width => '40em', :legend => ('%0.0f%' % version.completed_pourcent)) %>
|
|
19 |
<%= progress_bar([version.closed_percent, version.completed_percent], :width => '40em', :legend => ('%0.0f%' % version.completed_percent)) %>
|
|
20 | 20 |
<p class="progress-info"> |
21 | 21 |
<%= link_to(l(:label_x_issues, :count => version.issues_count), |
22 | 22 |
project_issues_path(version.project, :status_id => '*', :fixed_version_id => version, :set_filter => 1)) %> |
lib/redmine/helpers/gantt.rb | ||
---|---|---|
307 | 307 |
options[:zoom] ||= 1 |
308 | 308 |
options[:g_width] ||= (self.date_to - self.date_from + 1) * options[:zoom] |
309 | 309 |
coords = coordinates(version.start_date, |
310 |
version.due_date, version.completed_pourcent,
|
|
310 |
version.due_date, version.completed_percent,
|
|
311 | 311 |
options[:zoom]) |
312 |
label = "#{h version} #{h version.completed_pourcent.to_i.to_s}%"
|
|
312 |
label = "#{h version} #{h version.completed_percent.to_i.to_s}%"
|
|
313 | 313 |
label = h("#{version.project} -") + label unless @project && @project == version.project |
314 | 314 |
case options[:format] |
315 | 315 |
when :html |
public/stylesheets/application.css | ||
---|---|---|
702 | 702 |
table.progress td.closed { background: #BAE0BA none repeat scroll 0%; } |
703 | 703 |
table.progress td.done { background: #D3EDD3 none repeat scroll 0%; } |
704 | 704 |
table.progress td.todo { background: #eee none repeat scroll 0%; } |
705 |
p.pourcent {font-size: 80%;}
|
|
705 |
p.percent {font-size: 80%;}
|
|
706 | 706 |
p.progress-info {clear: left; font-size: 80%; margin-top:-4px; color:#777;} |
707 | 707 | |
708 | 708 |
#roadmap table.progress td { height: 1.2em; } |
test/unit/version_test.rb | ||
---|---|---|
46 | 46 |
def test_progress_should_be_0_with_no_assigned_issues |
47 | 47 |
project = Project.find(1) |
48 | 48 |
v = Version.create!(:project => project, :name => 'Progress') |
49 |
assert_equal 0, v.completed_pourcent
|
|
50 |
assert_equal 0, v.closed_pourcent
|
|
49 |
assert_equal 0, v.completed_percent
|
|
50 |
assert_equal 0, v.closed_percent
|
|
51 | 51 |
end |
52 | 52 | |
53 | 53 |
def test_progress_should_be_0_with_unbegun_assigned_issues |
... | ... | |
55 | 55 |
v = Version.create!(:project => project, :name => 'Progress') |
56 | 56 |
add_issue(v) |
57 | 57 |
add_issue(v, :done_ratio => 0) |
58 |
assert_progress_equal 0, v.completed_pourcent
|
|
59 |
assert_progress_equal 0, v.closed_pourcent
|
|
58 |
assert_progress_equal 0, v.completed_percent
|
|
59 |
assert_progress_equal 0, v.closed_percent
|
|
60 | 60 |
end |
61 | 61 | |
62 | 62 |
def test_progress_should_be_100_with_closed_assigned_issues |
... | ... | |
67 | 67 |
add_issue(v, :status => status, :done_ratio => 20) |
68 | 68 |
add_issue(v, :status => status, :done_ratio => 70, :estimated_hours => 25) |
69 | 69 |
add_issue(v, :status => status, :estimated_hours => 15) |
70 |
assert_progress_equal 100.0, v.completed_pourcent
|
|
71 |
assert_progress_equal 100.0, v.closed_pourcent
|
|
70 |
assert_progress_equal 100.0, v.completed_percent
|
|
71 |
assert_progress_equal 100.0, v.closed_percent
|
|
72 | 72 |
end |
73 | 73 | |
74 | 74 |
def test_progress_should_consider_done_ratio_of_open_assigned_issues |
... | ... | |
77 | 77 |
add_issue(v) |
78 | 78 |
add_issue(v, :done_ratio => 20) |
79 | 79 |
add_issue(v, :done_ratio => 70) |
80 |
assert_progress_equal (0.0 + 20.0 + 70.0)/3, v.completed_pourcent
|
|
81 |
assert_progress_equal 0, v.closed_pourcent
|
|
80 |
assert_progress_equal (0.0 + 20.0 + 70.0)/3, v.completed_percent
|
|
81 |
assert_progress_equal 0, v.closed_percent
|
|
82 | 82 |
end |
83 | 83 | |
84 | 84 |
def test_progress_should_consider_closed_issues_as_completed |
... | ... | |
87 | 87 |
add_issue(v) |
88 | 88 |
add_issue(v, :done_ratio => 20) |
89 | 89 |
add_issue(v, :status => IssueStatus.where(:is_closed => true).first) |
90 |
assert_progress_equal (0.0 + 20.0 + 100.0)/3, v.completed_pourcent
|
|
91 |
assert_progress_equal (100.0)/3, v.closed_pourcent
|
|
90 |
assert_progress_equal (0.0 + 20.0 + 100.0)/3, v.completed_percent
|
|
91 |
assert_progress_equal (100.0)/3, v.closed_percent
|
|
92 | 92 |
end |
93 | 93 | |
94 | 94 |
def test_progress_should_consider_estimated_hours_to_weigth_issues |
... | ... | |
98 | 98 |
add_issue(v, :estimated_hours => 20, :done_ratio => 30) |
99 | 99 |
add_issue(v, :estimated_hours => 40, :done_ratio => 10) |
100 | 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_pourcent
|
|
102 |
assert_progress_equal 25.0/95.0*100, v.closed_pourcent
|
|
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_percent
|
|
103 | 103 |
end |
104 | 104 | |
105 | 105 |
def test_progress_should_consider_average_estimated_hours_to_weigth_unestimated_issues |
... | ... | |
109 | 109 |
add_issue(v, :status => IssueStatus.where(:is_closed => true).first) |
110 | 110 |
add_issue(v, :estimated_hours => 10, :done_ratio => 30) |
111 | 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_pourcent
|
|
113 |
assert_progress_equal 25.0/100.0*100, v.closed_pourcent
|
|
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_percent
|
|
114 | 114 |
end |
115 | 115 | |
116 | 116 |
def test_should_sort_scheduled_then_unscheduled_versions |
... | ... | |
152 | 152 |
@version.update_attribute(:effective_date, 7.days.from_now.to_date) |
153 | 153 |
add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left |
154 | 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_pourcent
|
|
155 |
assert_equal 60, @version.completed_percent
|
|
156 | 156 |
assert_equal false, @version.behind_schedule? |
157 | 157 |
end |
158 | 158 | |
... | ... | |
160 | 160 |
@version.update_attribute(:effective_date, 7.days.from_now.to_date) |
161 | 161 |
add_issue(@version, :start_date => 7.days.ago, :done_ratio => 60) # 14 day span, 60% done, 50% time left |
162 | 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_pourcent
|
|
163 |
assert_equal 40, @version.completed_percent
|
|
164 | 164 |
assert_equal true, @version.behind_schedule? |
165 | 165 |
end |
166 | 166 | |
... | ... | |
168 | 168 |
@version.update_attribute(:effective_date, 7.days.from_now.to_date) |
169 | 169 |
add_issue(@version, :start_date => 14.days.ago, :done_ratio => 100, :status => IssueStatus.find(5)) # 7 day span |
170 | 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_pourcent
|
|
171 |
assert_equal 100, @version.completed_percent
|
|
172 | 172 |
assert_equal false, @version.behind_schedule? |
173 | 173 |
end |
174 | 174 |
end |