summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2015-04-14 17:01:23 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2015-04-14 17:01:23 +0000
commita9f052532e3ea4267714610307036558929ea672 (patch)
tree84af874af5372caf28c4960dcf81e23722e78453 /test
parent0a32e898f1ce39163ab60be56cf68ffad9a191b3 (diff)
downloadredmine-a9f052532e3ea4267714610307036558929ea672.tar.gz
redmine-a9f052532e3ea4267714610307036558929ea672.zip
Fixed workflow rules when user has duplicated role by inheritance (#19569).
git-svn-id: http://svn.redmine.org/redmine/trunk@14179 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r--test/unit/issue_test.rb21
-rw-r--r--test/unit/member_test.rb10
-rw-r--r--test/unit/user_test.rb12
3 files changed, 43 insertions, 0 deletions
diff --git a/test/unit/issue_test.rb b/test/unit/issue_test.rb
index 5d11f8cc3..fca74cdbc 100644
--- a/test/unit/issue_test.rb
+++ b/test/unit/issue_test.rb
@@ -981,6 +981,27 @@ class IssueTest < ActiveSupport::TestCase
assert_equal %w(done_ratio start_date), issue.read_only_attribute_names(user).sort
end
+ def test_workflow_rules_should_work_for_member_with_duplicate_role
+ WorkflowPermission.delete_all
+ WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1,
+ :role_id => 1, :field_name => 'due_date',
+ :rule => 'required')
+ WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1,
+ :role_id => 1, :field_name => 'start_date',
+ :rule => 'readonly')
+
+ user = User.generate!
+ m = Member.new(:user_id => user.id, :project_id => 1)
+ m.member_roles.build(:role_id => 1)
+ m.member_roles.build(:role_id => 1)
+ m.save!
+
+ 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(start_date), issue.read_only_attribute_names(user)
+ end
+
def test_copy
issue = Issue.new.copy_from(1)
assert issue.copy?
diff --git a/test/unit/member_test.rb b/test/unit/member_test.rb
index 97ba59079..2ed65543b 100644
--- a/test/unit/member_test.rb
+++ b/test/unit/member_test.rb
@@ -133,6 +133,16 @@ class MemberTest < ActiveSupport::TestCase
Member._destroy_callbacks.delete(:destroy_test_callback)
end
+ def test_roles_should_be_unique
+ m = Member.new(:user_id => 1, :project_id => 1)
+ m.member_roles.build(:role_id => 1)
+ m.member_roles.build(:role_id => 1)
+ m.save!
+ m.reload
+ assert_equal 1, m.roles.count
+ assert_equal [1], m.roles.ids
+ end
+
def test_sort_without_roles
a = Member.new(:roles => [Role.first])
b = Member.new
diff --git a/test/unit/user_test.rb b/test/unit/user_test.rb
index 429f2908b..831ff577d 100644
--- a/test/unit/user_test.rb
+++ b/test/unit/user_test.rb
@@ -907,6 +907,18 @@ class UserTest < ActiveSupport::TestCase
assert_equal [], roles.map(&:name).sort
end
+ def test_roles_for_project_should_be_unique
+ m = Member.new(:user_id => 1, :project_id => 1)
+ m.member_roles.build(:role_id => 1)
+ m.member_roles.build(:role_id => 1)
+ m.save!
+
+ user = User.find(1)
+ project = Project.find(1)
+ assert_equal 1, user.roles_for_project(project).size
+ assert_equal [1], user.roles_for_project(project).map(&:id)
+ end
+
def test_projects_by_role_for_user_with_role
user = User.find(2)
assert_kind_of Hash, user.projects_by_role