diff options
author | Marius Balteanu <marius.balteanu@zitec.com> | 2022-03-22 07:03:19 +0000 |
---|---|---|
committer | Marius Balteanu <marius.balteanu@zitec.com> | 2022-03-22 07:03:19 +0000 |
commit | 30d91c85036132b3524845fee4746ae014c293d4 (patch) | |
tree | b8149e62d1826d031ba7309d149b082b8fd882f1 /test | |
parent | 2e86acfa8742651c47fe5719c6d458299a428003 (diff) | |
download | redmine-30d91c85036132b3524845fee4746ae014c293d4.tar.gz redmine-30d91c85036132b3524845fee4746ae014c293d4.zip |
Fix that Log time and/or Add notes sections from issue form page do not show or hide dynamically based on user permission (#34641).
git-svn-id: https://svn.redmine.org/redmine/trunk@21495 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r-- | test/application_system_test_case.rb | 6 | ||||
-rw-r--r-- | test/system/issues_test.rb | 37 |
2 files changed, 43 insertions, 0 deletions
diff --git a/test/application_system_test_case.rb b/test/application_system_test_case.rb index a8b6f55d5..d813f0ce3 100644 --- a/test/application_system_test_case.rb +++ b/test/application_system_test_case.rb @@ -81,6 +81,12 @@ class ApplicationSystemTestCase < ActionDispatch::SystemTestCase assert_equal '/my/page', current_path end + def wait_for_ajax + Timeout.timeout(Capybara.default_max_wait_time) do + loop until page.evaluate_script("jQuery.active").zero? + end + end + def clear_downloaded_files FileUtils.rm downloaded_files end diff --git a/test/system/issues_test.rb b/test/system/issues_test.rb index 4d0486088..935470e1a 100644 --- a/test/system/issues_test.rb +++ b/test/system/issues_test.rb @@ -587,4 +587,41 @@ class IssuesSystemTest < ApplicationSystemTestCase assert page.has_text? 'Related to Bug #7' end end + + def test_update_issue_form_should_include_time_entry_form_only_for_users_with_permission + log_user('jsmith', 'jsmith') + + visit '/issues/2' + page.first(:link, 'Edit').click + + # assert log time form exits for user with required permissions on the current project + assert page.has_css?('#log_time') + + # Change project to trigger an update on issue form + page.find('#issue_project_id').select('» Private child of eCookbook') + wait_for_ajax + + # assert log time form does not exist anymore for user without required permissions on the new project + assert_not page.has_css?('#log_time') + end + + def test_update_issue_form_should_include_add_notes_form_only_for_users_with_permission + log_user('jsmith', 'jsmith') + + visit '/issues/2' + page.first(:link, 'Edit').click + + # assert add notes form exits for user with required permissions on the current project + assert page.has_css?('#add_notes') + + # remove add issue notes permission from Manager role + Role.find_by_name('Manager').remove_permission! :add_issue_notes + + # Change project to trigger an update on issue form + page.find('#issue_project_id').select('» Private child of eCookbook') + wait_for_ajax + + # assert add notes form does not exist anymore for user without required permissions on the new project + assert_not page.has_css?('#add_notes') + end end |