]> source.dussan.org Git - redmine.git/commitdiff
Duplicate activities in time entry report when project-specific activies exist (...
authorGo MAEDA <maeda@farend.jp>
Wed, 19 Jan 2022 13:33:11 +0000 (13:33 +0000)
committerGo MAEDA <maeda@farend.jp>
Wed, 19 Jan 2022 13:33:11 +0000 (13:33 +0000)
Patch by Yuichi HARADA.

git-svn-id: http://svn.redmine.org/redmine/trunk@21371 e93f8b46-1217-0410-a6f0-8f06a7374b81

lib/redmine/helpers/time_report.rb
test/functional/timelog_report_test.rb

index cac5f242732accef8e0674158fa330d1ca5785e7..2ae5fd8eb47b830832cef70d97434a82520f7e38 100644 (file)
@@ -122,7 +122,7 @@ module Redmine
           'tracker' => {:sql => "#{Issue.table_name}.tracker_id",
                         :klass => Tracker,
                         :label => :label_tracker},
-          'activity' => {:sql => "#{TimeEntry.table_name}.activity_id",
+          'activity' => {:sql => "COALESCE(#{TimeEntryActivity.table_name}.parent_id, #{TimeEntryActivity.table_name}.id)",
                          :klass => TimeEntryActivity,
                          :label => :field_activity},
           'issue' => {:sql => "#{TimeEntry.table_name}.issue_id",
index a3c085db2cac804025b47fc6932955371fa91969..d72491418ce941a91d3009fe2cd3ae3bbcb3edb6 100644 (file)
@@ -224,6 +224,19 @@ class TimelogReportTest < Redmine::ControllerTest
     assert_select 'td', :text => 'New'
   end
 
+  def test_report_activity_criterion_should_aggregate_system_activity_and_project_activity
+    activity = TimeEntryActivity.create!(:name => 'Design', :parent_id => 9, :project_id => 3)
+    TimeEntry.generate!(:project_id => 3, :issue_id => 5, :activity_id => activity.id, :spent_on => '2007-05-23', :hours => 10.0)
+
+    get :report, :params => {:project_id => 1, :criteria => ['activity']}
+    assert_response :success
+
+    assert_select 'tr.last-level:first' do
+      assert_select 'td.name', :text => 'Design'
+      assert_select 'td.hours:last', :text => '165:15'
+    end
+  end
+
   def test_report_all_projects_csv_export
     get :report, :params => {
       :columns => 'month',