chris@37
|
1 # -*- coding: utf-8 -*-
|
Chris@119
|
2 require File.expand_path('../../test_helper', __FILE__)
|
chris@37
|
3
|
chris@37
|
4 class TimeEntryReportsControllerTest < ActionController::TestCase
|
chris@37
|
5 fixtures :projects, :enabled_modules, :roles, :members, :member_roles, :issues, :time_entries, :users, :trackers, :enumerations, :issue_statuses, :custom_fields, :custom_values
|
chris@37
|
6
|
Chris@441
|
7 def test_report_at_project_level
|
Chris@441
|
8 get :report, :project_id => 'ecookbook'
|
chris@37
|
9 assert_response :success
|
chris@37
|
10 assert_template 'report'
|
Chris@441
|
11 assert_tag :form,
|
Chris@441
|
12 :attributes => {:action => "/projects/ecookbook/time_entries/report", :id => 'query_form'}
|
chris@37
|
13 end
|
chris@37
|
14
|
chris@37
|
15 def test_report_all_projects
|
chris@37
|
16 get :report
|
chris@37
|
17 assert_response :success
|
chris@37
|
18 assert_template 'report'
|
Chris@441
|
19 assert_tag :form,
|
Chris@441
|
20 :attributes => {:action => "/time_entries/report", :id => 'query_form'}
|
chris@37
|
21 end
|
chris@37
|
22
|
chris@37
|
23 def test_report_all_projects_denied
|
chris@37
|
24 r = Role.anonymous
|
chris@37
|
25 r.permissions.delete(:view_time_entries)
|
chris@37
|
26 r.permissions_will_change!
|
chris@37
|
27 r.save
|
chris@37
|
28 get :report
|
chris@37
|
29 assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Ftime_entries%2Freport'
|
chris@37
|
30 end
|
chris@37
|
31
|
chris@37
|
32 def test_report_all_projects_one_criteria
|
chris@37
|
33 get :report, :columns => 'week', :from => "2007-04-01", :to => "2007-04-30", :criterias => ['project']
|
chris@37
|
34 assert_response :success
|
chris@37
|
35 assert_template 'report'
|
chris@37
|
36 assert_not_nil assigns(:total_hours)
|
chris@37
|
37 assert_equal "8.65", "%.2f" % assigns(:total_hours)
|
chris@37
|
38 end
|
chris@37
|
39
|
chris@37
|
40 def test_report_all_time
|
chris@37
|
41 get :report, :project_id => 1, :criterias => ['project', 'issue']
|
chris@37
|
42 assert_response :success
|
chris@37
|
43 assert_template 'report'
|
chris@37
|
44 assert_not_nil assigns(:total_hours)
|
chris@37
|
45 assert_equal "162.90", "%.2f" % assigns(:total_hours)
|
chris@37
|
46 end
|
chris@37
|
47
|
chris@37
|
48 def test_report_all_time_by_day
|
chris@37
|
49 get :report, :project_id => 1, :criterias => ['project', 'issue'], :columns => 'day'
|
chris@37
|
50 assert_response :success
|
chris@37
|
51 assert_template 'report'
|
chris@37
|
52 assert_not_nil assigns(:total_hours)
|
chris@37
|
53 assert_equal "162.90", "%.2f" % assigns(:total_hours)
|
chris@37
|
54 assert_tag :tag => 'th', :content => '2007-03-12'
|
chris@37
|
55 end
|
chris@37
|
56
|
chris@37
|
57 def test_report_one_criteria
|
chris@37
|
58 get :report, :project_id => 1, :columns => 'week', :from => "2007-04-01", :to => "2007-04-30", :criterias => ['project']
|
chris@37
|
59 assert_response :success
|
chris@37
|
60 assert_template 'report'
|
chris@37
|
61 assert_not_nil assigns(:total_hours)
|
chris@37
|
62 assert_equal "8.65", "%.2f" % assigns(:total_hours)
|
chris@37
|
63 end
|
chris@37
|
64
|
chris@37
|
65 def test_report_two_criterias
|
chris@37
|
66 get :report, :project_id => 1, :columns => 'month', :from => "2007-01-01", :to => "2007-12-31", :criterias => ["member", "activity"]
|
chris@37
|
67 assert_response :success
|
chris@37
|
68 assert_template 'report'
|
chris@37
|
69 assert_not_nil assigns(:total_hours)
|
chris@37
|
70 assert_equal "162.90", "%.2f" % assigns(:total_hours)
|
chris@37
|
71 end
|
chris@37
|
72
|
chris@37
|
73 def test_report_one_day
|
chris@37
|
74 get :report, :project_id => 1, :columns => 'day', :from => "2007-03-23", :to => "2007-03-23", :criterias => ["member", "activity"]
|
chris@37
|
75 assert_response :success
|
chris@37
|
76 assert_template 'report'
|
chris@37
|
77 assert_not_nil assigns(:total_hours)
|
chris@37
|
78 assert_equal "4.25", "%.2f" % assigns(:total_hours)
|
chris@37
|
79 end
|
chris@37
|
80
|
chris@37
|
81 def test_report_at_issue_level
|
chris@37
|
82 get :report, :project_id => 1, :issue_id => 1, :columns => 'month', :from => "2007-01-01", :to => "2007-12-31", :criterias => ["member", "activity"]
|
chris@37
|
83 assert_response :success
|
chris@37
|
84 assert_template 'report'
|
chris@37
|
85 assert_not_nil assigns(:total_hours)
|
chris@37
|
86 assert_equal "154.25", "%.2f" % assigns(:total_hours)
|
Chris@441
|
87 assert_tag :form,
|
Chris@441
|
88 :attributes => {:action => "/projects/ecookbook/issues/1/time_entries/report", :id => 'query_form'}
|
chris@37
|
89 end
|
chris@37
|
90
|
chris@37
|
91 def test_report_custom_field_criteria
|
chris@37
|
92 get :report, :project_id => 1, :criterias => ['project', 'cf_1', 'cf_7']
|
chris@37
|
93 assert_response :success
|
chris@37
|
94 assert_template 'report'
|
chris@37
|
95 assert_not_nil assigns(:total_hours)
|
chris@37
|
96 assert_not_nil assigns(:criterias)
|
chris@37
|
97 assert_equal 3, assigns(:criterias).size
|
chris@37
|
98 assert_equal "162.90", "%.2f" % assigns(:total_hours)
|
chris@37
|
99 # Custom field column
|
chris@37
|
100 assert_tag :tag => 'th', :content => 'Database'
|
chris@37
|
101 # Custom field row
|
chris@37
|
102 assert_tag :tag => 'td', :content => 'MySQL',
|
chris@37
|
103 :sibling => { :tag => 'td', :attributes => { :class => 'hours' },
|
chris@37
|
104 :child => { :tag => 'span', :attributes => { :class => 'hours hours-int' },
|
chris@37
|
105 :content => '1' }}
|
chris@37
|
106 # Second custom field column
|
chris@37
|
107 assert_tag :tag => 'th', :content => 'Billable'
|
chris@37
|
108 end
|
chris@37
|
109
|
chris@37
|
110 def test_report_one_criteria_no_result
|
chris@37
|
111 get :report, :project_id => 1, :columns => 'week', :from => "1998-04-01", :to => "1998-04-30", :criterias => ['project']
|
chris@37
|
112 assert_response :success
|
chris@37
|
113 assert_template 'report'
|
chris@37
|
114 assert_not_nil assigns(:total_hours)
|
chris@37
|
115 assert_equal "0.00", "%.2f" % assigns(:total_hours)
|
chris@37
|
116 end
|
chris@37
|
117
|
chris@37
|
118 def test_report_all_projects_csv_export
|
chris@37
|
119 get :report, :columns => 'month', :from => "2007-01-01", :to => "2007-06-30", :criterias => ["project", "member", "activity"], :format => "csv"
|
chris@37
|
120 assert_response :success
|
chris@37
|
121 assert_equal 'text/csv', @response.content_type
|
chris@37
|
122 lines = @response.body.chomp.split("\n")
|
chris@37
|
123 # Headers
|
chris@37
|
124 assert_equal 'Project,Member,Activity,2007-1,2007-2,2007-3,2007-4,2007-5,2007-6,Total', lines.first
|
chris@37
|
125 # Total row
|
chris@37
|
126 assert_equal 'Total,"","","","",154.25,8.65,"","",162.90', lines.last
|
chris@37
|
127 end
|
chris@37
|
128
|
chris@37
|
129 def test_report_csv_export
|
chris@37
|
130 get :report, :project_id => 1, :columns => 'month', :from => "2007-01-01", :to => "2007-06-30", :criterias => ["project", "member", "activity"], :format => "csv"
|
chris@37
|
131 assert_response :success
|
chris@37
|
132 assert_equal 'text/csv', @response.content_type
|
chris@37
|
133 lines = @response.body.chomp.split("\n")
|
chris@37
|
134 # Headers
|
chris@37
|
135 assert_equal 'Project,Member,Activity,2007-1,2007-2,2007-3,2007-4,2007-5,2007-6,Total', lines.first
|
chris@37
|
136 # Total row
|
chris@37
|
137 assert_equal 'Total,"","","","",154.25,8.65,"","",162.90', lines.last
|
chris@37
|
138 end
|
chris@37
|
139
|
chris@37
|
140 end
|