diff options
author | Go MAEDA <maeda@farend.jp> | 2021-03-15 23:36:27 +0000 |
---|---|---|
committer | Go MAEDA <maeda@farend.jp> | 2021-03-15 23:36:27 +0000 |
commit | 1accf2a072bfa34b77162c29f42e556b8ec54056 (patch) | |
tree | 2c605d8282bf883980c7af4a312679a90e4cfa40 /test | |
parent | c54349cc0b33dcc3f2a6a17661cc0d216e0e8736 (diff) | |
download | redmine-1accf2a072bfa34b77162c29f42e556b8ec54056.tar.gz redmine-1accf2a072bfa34b77162c29f42e556b8ec54056.zip |
Delete spent time custom field values not visible by the user after assignment (#33550).
Patch by Marius BALTEANU.
git-svn-id: http://svn.redmine.org/redmine/trunk@20802 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/time_entry_custom_field_test.rb | 75 | ||||
-rw-r--r-- | test/unit/time_entry_test.rb | 3 |
2 files changed, 77 insertions, 1 deletions
diff --git a/test/unit/time_entry_custom_field_test.rb b/test/unit/time_entry_custom_field_test.rb new file mode 100644 index 000000000..115289d89 --- /dev/null +++ b/test/unit/time_entry_custom_field_test.rb @@ -0,0 +1,75 @@ +# frozen_string_literal: true + +# Redmine - project management software +# Copyright (C) 2006-2020 Jean-Philippe Lang +# +# 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 TimeEntryCustomFieldTest < ActiveSupport::TestCase + include Redmine::I18n + + fixtures :roles + + def setup + User.current = nil + end + + def test_custom_field_with_visible_set_to_false_should_validate_roles + set_language_if_valid 'en' + field = TimeEntryCustomField.new(:name => 'Field', :field_format => 'string', :visible => false) + assert !field.save + assert_include "Roles cannot be blank", field.errors.full_messages + field.role_ids = [1, 2] + assert field.save + end + + def test_changing_visible_to_true_should_clear_roles + field = TimeEntryCustomField.create!(:name => 'Field', :field_format => 'string', :visible => false, :role_ids => [1, 2]) + assert_equal 2, field.roles.count + + field.visible = true + field.save! + assert_equal 0, field.roles.count + end + + def test_safe_attributes_should_include_only_custom_fields_visible_to_user + cf1 = TimeEntryCustomField.create!(:name => 'Visible field', + :field_format => 'string', + :visible => false, :role_ids => [1]) + cf2 = TimeEntryCustomField.create!(:name => 'Non visible field', + :field_format => 'string', + :visible => false, :role_ids => [3]) + user = User.find(2) + time_entry = TimeEntry.new(:issue_id => 1) + + time_entry.send :safe_attributes=, {'custom_field_values' => { + cf1.id.to_s => 'value1', + cf2.id.to_s => 'value2' + }}, user + + assert_equal 'value1', time_entry.custom_field_value(cf1) + assert_nil time_entry.custom_field_value(cf2) + + time_entry.send :safe_attributes=, {'custom_fields' => [ + {'id' => cf1.id.to_s, 'value' => 'valuea'}, + {'id' => cf2.id.to_s, 'value' => 'valueb'} + ]}, user + + assert_equal 'valuea', time_entry.custom_field_value(cf1) + assert_nil time_entry.custom_field_value(cf2) + end +end diff --git a/test/unit/time_entry_test.rb b/test/unit/time_entry_test.rb index 636e09748..2ebdba1be 100644 --- a/test/unit/time_entry_test.rb +++ b/test/unit/time_entry_test.rb @@ -29,7 +29,8 @@ class TimeEntryTest < ActiveSupport::TestCase :journals, :journal_details, :issue_categories, :enumerations, :groups_users, - :enabled_modules + :enabled_modules, + :custom_fields, :custom_fields_projects, :custom_values def setup User.current = nil |