From 1fad29bc146bcd939a50dcfe29ad7f258eaf84a8 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Sat, 25 Apr 2015 07:40:46 +0000 Subject: [PATCH] Merged r14179 (#19569). git-svn-id: http://svn.redmine.org/redmine/branches/3.0-stable@14210 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/models/member.rb | 2 +- test/unit/issue_test.rb | 21 +++++++++++++++++++++ test/unit/member_test.rb | 10 ++++++++++ test/unit/user_test.rb | 12 ++++++++++++ 4 files changed, 44 insertions(+), 1 deletion(-) diff --git a/app/models/member.rb b/app/models/member.rb index b76e37dbd..72a92db53 100644 --- a/app/models/member.rb +++ b/app/models/member.rb @@ -19,7 +19,7 @@ class Member < ActiveRecord::Base belongs_to :user belongs_to :principal, :foreign_key => 'user_id' has_many :member_roles, :dependent => :destroy - has_many :roles, :through => :member_roles + has_many :roles, lambda {uniq}, :through => :member_roles belongs_to :project validates_presence_of :principal, :project diff --git a/test/unit/issue_test.rb b/test/unit/issue_test.rb index 61b24c10d..70a22ab77 100644 --- a/test/unit/issue_test.rb +++ b/test/unit/issue_test.rb @@ -958,6 +958,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 -- 2.39.5