You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

time_entry_custom_field_test.rb 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. # frozen_string_literal: true
  2. # Redmine - project management software
  3. # Copyright (C) 2006- Jean-Philippe Lang
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU General Public License
  7. # as published by the Free Software Foundation; either version 2
  8. # of the License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. require_relative '../test_helper'
  19. class TimeEntryCustomFieldTest < ActiveSupport::TestCase
  20. include Redmine::I18n
  21. fixtures :roles, :users, :members, :member_roles, :projects, :enabled_modules, :issues
  22. def setup
  23. User.current = nil
  24. end
  25. def test_custom_field_with_visible_set_to_false_should_validate_roles
  26. set_language_if_valid 'en'
  27. field = TimeEntryCustomField.new(:name => 'Field', :field_format => 'string', :visible => false)
  28. assert !field.save
  29. assert_include "Roles cannot be blank", field.errors.full_messages
  30. field.role_ids = [1, 2]
  31. assert field.save
  32. end
  33. def test_changing_visible_to_true_should_clear_roles
  34. field = TimeEntryCustomField.create!(:name => 'Field', :field_format => 'string', :visible => false, :role_ids => [1, 2])
  35. assert_equal 2, field.roles.count
  36. field.visible = true
  37. field.save!
  38. assert_equal 0, field.roles.count
  39. end
  40. def test_safe_attributes_should_include_only_custom_fields_visible_to_user
  41. cf1 = TimeEntryCustomField.create!(:name => 'Visible field',
  42. :field_format => 'string',
  43. :visible => false, :role_ids => [1])
  44. cf2 = TimeEntryCustomField.create!(:name => 'Non visible field',
  45. :field_format => 'string',
  46. :visible => false, :role_ids => [3])
  47. user = User.find(2)
  48. time_entry = TimeEntry.new(:issue_id => 1)
  49. time_entry.send :safe_attributes=, {'custom_field_values' => {
  50. cf1.id.to_s => 'value1',
  51. cf2.id.to_s => 'value2'
  52. }}, user
  53. assert_equal 'value1', time_entry.custom_field_value(cf1)
  54. assert_nil time_entry.custom_field_value(cf2)
  55. time_entry.send :safe_attributes=, {'custom_fields' => [
  56. {'id' => cf1.id.to_s, 'value' => 'valuea'},
  57. {'id' => cf2.id.to_s, 'value' => 'valueb'}
  58. ]}, user
  59. assert_equal 'valuea', time_entry.custom_field_value(cf1)
  60. assert_nil time_entry.custom_field_value(cf2)
  61. end
  62. end