##// END OF EJS Templates
add unit test of member_role validate...
Toshi MARUYAMA -
r7947:747afd808839
parent child
Show More
@@ -1,157 +1,166
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 require File.expand_path('../../test_helper', __FILE__)
19 19
20 20 class MemberTest < ActiveSupport::TestCase
21 21 fixtures :projects, :trackers, :issue_statuses, :issues,
22 22 :enumerations, :users, :issue_categories,
23 23 :projects_trackers,
24 24 :roles,
25 25 :member_roles,
26 26 :members,
27 27 :enabled_modules,
28 28 :workflows,
29 29 :groups_users,
30 30 :watchers,
31 31 :journals, :journal_details,
32 32 :messages,
33 33 :wikis, :wiki_pages, :wiki_contents, :wiki_content_versions,
34 34 :boards
35 35
36 36 def setup
37 37 @jsmith = Member.find(1)
38 38 end
39 39
40 40 def test_create
41 41 member = Member.new(:project_id => 1, :user_id => 4, :role_ids => [1, 2])
42 42 assert member.save
43 43 member.reload
44 44
45 45 assert_equal 2, member.roles.size
46 46 assert_equal Role.find(1), member.roles.sort.first
47 47 end
48 48
49 49 def test_update
50 50 assert_equal "eCookbook", @jsmith.project.name
51 51 assert_equal "Manager", @jsmith.roles.first.name
52 52 assert_equal "jsmith", @jsmith.user.login
53 53
54 54 @jsmith.mail_notification = !@jsmith.mail_notification
55 55 assert @jsmith.save
56 56 end
57 57
58 58 def test_update_roles
59 59 assert_equal 1, @jsmith.roles.size
60 60 @jsmith.role_ids = [1, 2]
61 61 assert @jsmith.save
62 62 assert_equal 2, @jsmith.reload.roles.size
63 63 end
64 64
65 65 def test_validate
66 66 member = Member.new(:project_id => 1, :user_id => 2, :role_ids => [2])
67 67 # same use can't have more than one membership for a project
68 68 assert !member.save
69 69
70 70 # must have one role at least
71 71 user = User.new(:firstname => "new1", :lastname => "user1", :mail => "test_validate@somenet.foo")
72 72 user.login = "test_validate"
73 73 user.password, user.password_confirmation = "password", "password"
74 74 assert user.save
75 75 member = Member.new(:project_id => 1, :user_id => user.id, :role_ids => [])
76 76 assert !member.save
77 77 end
78 78
79 def test_validate_member_role
80 user = User.new(:firstname => "new1", :lastname => "user1", :mail => "test_validate@somenet.foo")
81 user.login = "test_validate_member_role"
82 user.password, user.password_confirmation = "password", "password"
83 assert user.save
84 member = Member.new(:project_id => 1, :user_id => user.id, :role_ids => [5])
85 assert !member.save
86 end
87
79 88 def test_destroy
80 89 category1 = IssueCategory.find(1)
81 90 assert_equal @jsmith.user.id, category1.assigned_to_id
82 91 assert_difference 'Member.count', -1 do
83 92 assert_difference 'MemberRole.count', -1 do
84 93 @jsmith.destroy
85 94 end
86 95 end
87 96 assert_raise(ActiveRecord::RecordNotFound) { Member.find(@jsmith.id) }
88 97 category1.reload
89 98 assert_nil category1.assigned_to_id
90 99 end
91 100
92 101 context "removing permissions" do
93 102 setup do
94 103 Watcher.delete_all("user_id = 9")
95 104 user = User.find(9)
96 105 # public
97 106 Watcher.create!(:watchable => Issue.find(1), :user => user)
98 107 # private
99 108 Watcher.create!(:watchable => Issue.find(4), :user => user)
100 109 Watcher.create!(:watchable => Message.find(7), :user => user)
101 110 Watcher.create!(:watchable => Wiki.find(2), :user => user)
102 111 Watcher.create!(:watchable => WikiPage.find(3), :user => user)
103 112 end
104 113
105 114 context "of user" do
106 115 setup do
107 116 @member = Member.create!(:project => Project.find(2), :principal => User.find(9), :role_ids => [1, 2])
108 117 end
109 118
110 119 context "by deleting membership" do
111 120 should "prune watchers" do
112 121 assert_difference 'Watcher.count', -4 do
113 122 @member.destroy
114 123 end
115 124 end
116 125 end
117 126
118 127 context "by updating roles" do
119 128 should "prune watchers" do
120 129 Role.find(2).remove_permission! :view_wiki_pages
121 130 member = Member.first(:order => 'id desc')
122 131 assert_difference 'Watcher.count', -2 do
123 132 member.role_ids = [2]
124 133 member.save
125 134 end
126 135 assert !Message.find(7).watched_by?(@user)
127 136 end
128 137 end
129 138 end
130 139
131 140 context "of group" do
132 141 setup do
133 142 group = Group.find(10)
134 143 @member = Member.create!(:project => Project.find(2), :principal => group, :role_ids => [1, 2])
135 144 group.users << User.find(9)
136 145 end
137 146
138 147 context "by deleting membership" do
139 148 should "prune watchers" do
140 149 assert_difference 'Watcher.count', -4 do
141 150 @member.destroy
142 151 end
143 152 end
144 153 end
145 154
146 155 context "by updating roles" do
147 156 should "prune watchers" do
148 157 Role.find(2).remove_permission! :view_wiki_pages
149 158 assert_difference 'Watcher.count', -2 do
150 159 @member.role_ids = [2]
151 160 @member.save
152 161 end
153 162 end
154 163 end
155 164 end
156 165 end
157 166 end
General Comments 0
You need to be logged in to leave comments. Login now