summaryrefslogtreecommitdiffstats
path: root/test/unit/issue_test.rb
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2014-12-13 14:31:58 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2014-12-13 14:31:58 +0000
commit453803c68f24f1815ba001a70807dd65f909545c (patch)
tree497bf24bdd5093ae101dc5aad1ec93759aea45c3 /test/unit/issue_test.rb
parent07b44a46628c1fc5ac9797b3b376f48c986c8d1b (diff)
downloadredmine-453803c68f24f1815ba001a70807dd65f909545c.tar.gz
redmine-453803c68f24f1815ba001a70807dd65f909545c.zip
Don't consider roles without issue add/edit permissions for determining fields permissions (#15988).
git-svn-id: http://svn.redmine.org/redmine/trunk@13747 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/unit/issue_test.rb')
-rw-r--r--test/unit/issue_test.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/unit/issue_test.rb b/test/unit/issue_test.rb
index 101ae9e2d..5352fb790 100644
--- a/test/unit/issue_test.rb
+++ b/test/unit/issue_test.rb
@@ -914,6 +914,29 @@ class IssueTest < ActiveSupport::TestCase
assert_equal %w(due_date), issue.read_only_attribute_names(user)
end
+ def test_workflow_rules_should_ignore_roles_without_issue_permissions
+ role = Role.generate! :permissions => [:view_issues, :edit_issues]
+ ignored_role = Role.generate! :permissions => [:view_issues]
+
+ WorkflowPermission.delete_all
+ WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1,
+ :role => role, :field_name => 'due_date',
+ :rule => 'required')
+ WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1,
+ :role => role, :field_name => 'start_date',
+ :rule => 'readonly')
+ WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1,
+ :role => role, :field_name => 'done_ratio',
+ :rule => 'readonly')
+ user = User.generate!
+ User.add_to_project user, Project.find(1), [role, ignored_role]
+
+ issue = Issue.new(:project_id => 1, :tracker_id => 1, :status_id => 1)
+
+ assert_equal %w(due_date), issue.required_attribute_names(user)
+ assert_equal %w(done_ratio start_date), issue.read_only_attribute_names(user).sort
+ end
+
def test_copy
issue = Issue.new.copy_from(1)
assert issue.copy?