From 3afd17f83e6cc5c3314c7dab0499d56deda2ec12 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Sat, 2 Nov 2019 08:23:35 +0000 Subject: Allow import time entries for other users (#32196). Patch by Marius BALTEANU. git-svn-id: http://svn.redmine.org/redmine/trunk@18890 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- test/unit/time_entry_import_test.rb | 41 ++++++++++++++++++++++++++++++++++++- 1 file changed, 40 insertions(+), 1 deletion(-) (limited to 'test/unit/time_entry_import_test.rb') diff --git a/test/unit/time_entry_import_test.rb b/test/unit/time_entry_import_test.rb index cc732f0d7..d84de22f4 100644 --- a/test/unit/time_entry_import_test.rb +++ b/test/unit/time_entry_import_test.rb @@ -36,6 +36,7 @@ class TimeEntryImportTest < ActiveSupport::TestCase def setup set_language_if_valid 'en' + User.current = nil end def test_authorized @@ -125,6 +126,43 @@ class TimeEntryImportTest < ActiveSupport::TestCase assert_equal '0', fourth.custom_field_value(overtime_cf) end + def test_maps_user_id_for_user_with_permissions + User.current = User.find(1) + import = generate_import_with_mapping + first, second, third, fourth = new_records(TimeEntry, 4) { import.run } + + assert_equal 2, first.user_id + assert_equal 2, second.user_id + assert_equal 3, third.user_id + assert_equal 2, fourth.user_id + end + + def test_maps_user_to_column_value + User.current = User.find(1) + import = generate_import_with_mapping + import.mapping.merge!('user_id' => 'value:1') + import.save! + first, second, third, fourth = new_records(TimeEntry, 4) { import.run } + + assert_equal 1, first.user_id + assert_equal 1, second.user_id + assert_equal 1, third.user_id + assert_equal 1, fourth.user_id + end + + def test_maps_user_id_for_user_without_permissions + # User 2 doesn't have log_time_for_other_users permission + User.current = User.find(2) + import = generate_import_with_mapping + first, second, third, fourth = new_records(TimeEntry, 4) { import.run } + + assert_equal 2, first.user_id + assert_equal 2, second.user_id + # user_id value from CSV should be ignored + assert_equal 2, third.user_id + assert_equal 2, fourth.user_id + end + protected def generate_import(fixture_name='import_time_entries.csv') @@ -146,7 +184,8 @@ class TimeEntryImportTest < ActiveSupport::TestCase 'issue_id' => '1', 'spent_on' => '2', 'hours' => '3', - 'comments' => '4' + 'comments' => '4', + 'user_id' => '7' } } import.save! -- cgit v1.2.3