| 
									
										
										
										
											2013-07-13 09:20:11 +00:00
										 |  |  | # Redmine - project management software | 
					
						
							| 
									
										
										
										
											2014-01-29 22:45:39 +00:00
										 |  |  | # Copyright (C) 2006-2014  Jean-Philippe Lang | 
					
						
							| 
									
										
										
										
											2013-07-13 09:20:11 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  | # modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  | # as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  | # of the License, or (at your option) any later version. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | # but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | # GNU General Public License for more details. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | # along with this program; if not, write to the Free Software | 
					
						
							|  |  |  | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require File.expand_path('../../test_helper', __FILE__) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class TimelogCustomFieldsVisibilityTest < ActionController::TestCase | 
					
						
							|  |  |  |   tests TimelogController | 
					
						
							|  |  |  |   fixtures :projects, | 
					
						
							|  |  |  |            :users, | 
					
						
							|  |  |  |            :roles, | 
					
						
							|  |  |  |            :members, | 
					
						
							|  |  |  |            :member_roles, | 
					
						
							|  |  |  |            :issue_statuses, | 
					
						
							|  |  |  |            :trackers, | 
					
						
							|  |  |  |            :projects_trackers, | 
					
						
							|  |  |  |            :enabled_modules, | 
					
						
							|  |  |  |            :enumerations, | 
					
						
							|  |  |  |            :workflows | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def setup | 
					
						
							|  |  |  |     field_attributes = {:field_format => 'string', :is_for_all => true, :is_filter => true, :trackers => Tracker.all} | 
					
						
							|  |  |  |     @fields = [] | 
					
						
							|  |  |  |     @fields << (@field1 = IssueCustomField.create!(field_attributes.merge(:name => 'Field 1', :visible => true))) | 
					
						
							|  |  |  |     @fields << (@field2 = IssueCustomField.create!(field_attributes.merge(:name => 'Field 2', :visible => false, :role_ids => [1, 2]))) | 
					
						
							|  |  |  |     @fields << (@field3 = IssueCustomField.create!(field_attributes.merge(:name => 'Field 3', :visible => false, :role_ids => [1, 3]))) | 
					
						
							|  |  |  |     @issue = Issue.generate!( | 
					
						
							|  |  |  |       :author_id => 1, | 
					
						
							|  |  |  |       :project_id => 1, | 
					
						
							|  |  |  |       :tracker_id => 1, | 
					
						
							|  |  |  |       :custom_field_values => {@field1.id => 'Value0', @field2.id => 'Value1', @field3.id => 'Value2'} | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     TimeEntry.generate!(:issue => @issue) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @user_with_role_on_other_project = User.generate! | 
					
						
							|  |  |  |     User.add_to_project(@user_with_role_on_other_project, Project.find(2), Role.find(3)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @users_to_test = { | 
					
						
							|  |  |  |       User.find(1) => [@field1, @field2, @field3], | 
					
						
							|  |  |  |       User.find(3) => [@field1, @field2], | 
					
						
							|  |  |  |       @user_with_role_on_other_project => [@field1], # should see field1 only on Project 1 | 
					
						
							|  |  |  |       User.generate! => [@field1], | 
					
						
							|  |  |  |       User.anonymous => [@field1] | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Member.where(:project_id => 1).each do |member| | 
					
						
							|  |  |  |       member.destroy unless @users_to_test.keys.include?(member.principal) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def test_index_should_show_visible_custom_fields_only | 
					
						
							|  |  |  |     @users_to_test.each do |user, fields| | 
					
						
							|  |  |  |       @request.session[:user_id] = user.id | 
					
						
							|  |  |  |       get :index, :project_id => 1, :issue_id => @issue.id, :c => (['hours'] + @fields.map{|f| "issue.cf_#{f.id}"}) | 
					
						
							|  |  |  |       @fields.each_with_index do |field, i| | 
					
						
							|  |  |  |         if fields.include?(field) | 
					
						
							|  |  |  |           assert_select 'td', {:text => "Value#{i}", :count => 1}, "User #{user.id} was not able to view #{field.name}" | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           assert_select 'td', {:text => "Value#{i}", :count => 0}, "User #{user.id} was able to view #{field.name}" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def test_index_as_csv_should_show_visible_custom_fields_only | 
					
						
							|  |  |  |     @users_to_test.each do |user, fields| | 
					
						
							|  |  |  |       @request.session[:user_id] = user.id | 
					
						
							|  |  |  |       get :index, :project_id => 1, :issue_id => @issue.id, :c => (['hours'] + @fields.map{|f| "issue.cf_#{f.id}"}), :format => 'csv' | 
					
						
							|  |  |  |       @fields.each_with_index do |field, i| | 
					
						
							|  |  |  |         if fields.include?(field) | 
					
						
							|  |  |  |           assert_include "Value#{i}", response.body, "User #{user.id} was not able to view #{field.name} in CSV" | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           assert_not_include "Value#{i}", response.body, "User #{user.id} was able to view #{field.name} in CSV" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def test_index_with_partial_custom_field_visibility_should_show_visible_custom_fields_only | 
					
						
							|  |  |  |     Issue.delete_all | 
					
						
							|  |  |  |     TimeEntry.delete_all | 
					
						
							|  |  |  |     p1 = Project.generate! | 
					
						
							|  |  |  |     p2 = Project.generate! | 
					
						
							|  |  |  |     user = User.generate! | 
					
						
							| 
									
										
										
										
											2014-10-22 17:37:16 +00:00
										 |  |  |     User.add_to_project(user, p1, Role.where(:id => [1, 3]).to_a) | 
					
						
							|  |  |  |     User.add_to_project(user, p2, Role.where(:id => 3).to_a) | 
					
						
							| 
									
										
										
										
											2014-01-11 08:50:07 +00:00
										 |  |  |     TimeEntry.generate!( | 
					
						
							|  |  |  |       :issue => Issue.generate!(:project => p1, :tracker_id => 1, | 
					
						
							|  |  |  |                                 :custom_field_values => {@field2.id => 'ValueA'})) | 
					
						
							|  |  |  |     TimeEntry.generate!( | 
					
						
							|  |  |  |       :issue => Issue.generate!(:project => p2, :tracker_id => 1, | 
					
						
							|  |  |  |                                 :custom_field_values => {@field2.id => 'ValueB'})) | 
					
						
							|  |  |  |     TimeEntry.generate!( | 
					
						
							|  |  |  |       :issue => Issue.generate!(:project => p1, :tracker_id => 1, | 
					
						
							|  |  |  |                                 :custom_field_values => {@field2.id => 'ValueC'})) | 
					
						
							| 
									
										
										
										
											2013-07-13 09:20:11 +00:00
										 |  |  |     @request.session[:user_id] = user.id | 
					
						
							|  |  |  |     get :index, :c => ["hours", "issue.cf_#{@field2.id}"] | 
					
						
							| 
									
										
										
										
											2014-10-22 17:37:16 +00:00
										 |  |  |     assert_select 'td', {:text => 'ValueA'}, "ValueA not found in:\n#{response.body}" | 
					
						
							| 
									
										
										
										
											2013-07-13 09:20:11 +00:00
										 |  |  |     assert_select 'td', :text => 'ValueB', :count => 0
 | 
					
						
							| 
									
										
										
										
											2014-10-22 17:37:16 +00:00
										 |  |  |     assert_select 'td', {:text => 'ValueC'}, "ValueC not found in:\n#{response.body}" | 
					
						
							| 
									
										
										
										
											2013-07-13 09:20:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     get :index, :set_filter => '1', "issue.cf_#{@field2.id}" => '*' | 
					
						
							|  |  |  |     assert_equal %w(ValueA ValueC), assigns(:entries).map{|i| i.issue.custom_field_value(@field2)}.sort | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |