##// END OF EJS Templates
add test to check to set issue category assignee nil in destroying member...
Toshi MARUYAMA -
r7937:7a5d6f61c773
parent child
Show More
@@ -1,154 +1,157
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 79 def test_destroy
80 category1 = IssueCategory.find(1)
81 assert_equal @jsmith.user.id, category1.assigned_to_id
80 82 assert_difference 'Member.count', -1 do
81 83 assert_difference 'MemberRole.count', -1 do
82 84 @jsmith.destroy
83 85 end
84 86 end
85
86 87 assert_raise(ActiveRecord::RecordNotFound) { Member.find(@jsmith.id) }
88 category1.reload
89 assert_nil category1.assigned_to_id
87 90 end
88 91
89 92 context "removing permissions" do
90 93 setup do
91 94 Watcher.delete_all("user_id = 9")
92 95 user = User.find(9)
93 96 # public
94 97 Watcher.create!(:watchable => Issue.find(1), :user => user)
95 98 # private
96 99 Watcher.create!(:watchable => Issue.find(4), :user => user)
97 100 Watcher.create!(:watchable => Message.find(7), :user => user)
98 101 Watcher.create!(:watchable => Wiki.find(2), :user => user)
99 102 Watcher.create!(:watchable => WikiPage.find(3), :user => user)
100 103 end
101 104
102 105 context "of user" do
103 106 setup do
104 107 @member = Member.create!(:project => Project.find(2), :principal => User.find(9), :role_ids => [1, 2])
105 108 end
106 109
107 110 context "by deleting membership" do
108 111 should "prune watchers" do
109 112 assert_difference 'Watcher.count', -4 do
110 113 @member.destroy
111 114 end
112 115 end
113 116 end
114 117
115 118 context "by updating roles" do
116 119 should "prune watchers" do
117 120 Role.find(2).remove_permission! :view_wiki_pages
118 121 member = Member.first(:order => 'id desc')
119 122 assert_difference 'Watcher.count', -2 do
120 123 member.role_ids = [2]
121 124 member.save
122 125 end
123 126 assert !Message.find(7).watched_by?(@user)
124 127 end
125 128 end
126 129 end
127 130
128 131 context "of group" do
129 132 setup do
130 133 group = Group.find(10)
131 134 @member = Member.create!(:project => Project.find(2), :principal => group, :role_ids => [1, 2])
132 135 group.users << User.find(9)
133 136 end
134 137
135 138 context "by deleting membership" do
136 139 should "prune watchers" do
137 140 assert_difference 'Watcher.count', -4 do
138 141 @member.destroy
139 142 end
140 143 end
141 144 end
142 145
143 146 context "by updating roles" do
144 147 should "prune watchers" do
145 148 Role.find(2).remove_permission! :view_wiki_pages
146 149 assert_difference 'Watcher.count', -2 do
147 150 @member.role_ids = [2]
148 151 @member.save
149 152 end
150 153 end
151 154 end
152 155 end
153 156 end
154 157 end
General Comments 0
You need to be logged in to leave comments. Login now