##// END OF EJS Templates
add unit test of error message in case that member role is empty...
Toshi MARUYAMA -
r8006:740b54f55b65
parent child
Show More
@@ -1,166 +1,174
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 include Redmine::I18n
37
36 38 def setup
37 39 @jsmith = Member.find(1)
38 40 end
39 41
40 42 def test_create
41 43 member = Member.new(:project_id => 1, :user_id => 4, :role_ids => [1, 2])
42 44 assert member.save
43 45 member.reload
44 46
45 47 assert_equal 2, member.roles.size
46 48 assert_equal Role.find(1), member.roles.sort.first
47 49 end
48 50
49 51 def test_update
50 52 assert_equal "eCookbook", @jsmith.project.name
51 53 assert_equal "Manager", @jsmith.roles.first.name
52 54 assert_equal "jsmith", @jsmith.user.login
53 55
54 56 @jsmith.mail_notification = !@jsmith.mail_notification
55 57 assert @jsmith.save
56 58 end
57 59
58 60 def test_update_roles
59 61 assert_equal 1, @jsmith.roles.size
60 62 @jsmith.role_ids = [1, 2]
61 63 assert @jsmith.save
62 64 assert_equal 2, @jsmith.reload.roles.size
63 65 end
64 66
65 67 def test_validate
66 68 member = Member.new(:project_id => 1, :user_id => 2, :role_ids => [2])
67 69 # same use can't have more than one membership for a project
68 70 assert !member.save
69 71
70 72 # must have one role at least
71 73 user = User.new(:firstname => "new1", :lastname => "user1", :mail => "test_validate@somenet.foo")
72 74 user.login = "test_validate"
73 75 user.password, user.password_confirmation = "password", "password"
74 76 assert user.save
77
78 set_language_if_valid 'fr'
75 79 member = Member.new(:project_id => 1, :user_id => user.id, :role_ids => [])
76 80 assert !member.save
81 assert_equal I18n.translate('activerecord.errors.messages.empty'), member.errors[:role].to_s
82 str = "R\xc3\xb4le doit \xc3\xaatre renseign\xc3\xa9(e)"
83 str.force_encoding('UTF-8') if str.respond_to?(:force_encoding)
84 assert_equal str, member.errors.full_messages.to_s
77 85 end
78 86
79 87 def test_validate_member_role
80 88 user = User.new(:firstname => "new1", :lastname => "user1", :mail => "test_validate@somenet.foo")
81 89 user.login = "test_validate_member_role"
82 90 user.password, user.password_confirmation = "password", "password"
83 91 assert user.save
84 92 member = Member.new(:project_id => 1, :user_id => user.id, :role_ids => [5])
85 93 assert !member.save
86 94 end
87 95
88 96 def test_destroy
89 97 category1 = IssueCategory.find(1)
90 98 assert_equal @jsmith.user.id, category1.assigned_to_id
91 99 assert_difference 'Member.count', -1 do
92 100 assert_difference 'MemberRole.count', -1 do
93 101 @jsmith.destroy
94 102 end
95 103 end
96 104 assert_raise(ActiveRecord::RecordNotFound) { Member.find(@jsmith.id) }
97 105 category1.reload
98 106 assert_nil category1.assigned_to_id
99 107 end
100 108
101 109 context "removing permissions" do
102 110 setup do
103 111 Watcher.delete_all("user_id = 9")
104 112 user = User.find(9)
105 113 # public
106 114 Watcher.create!(:watchable => Issue.find(1), :user => user)
107 115 # private
108 116 Watcher.create!(:watchable => Issue.find(4), :user => user)
109 117 Watcher.create!(:watchable => Message.find(7), :user => user)
110 118 Watcher.create!(:watchable => Wiki.find(2), :user => user)
111 119 Watcher.create!(:watchable => WikiPage.find(3), :user => user)
112 120 end
113 121
114 122 context "of user" do
115 123 setup do
116 124 @member = Member.create!(:project => Project.find(2), :principal => User.find(9), :role_ids => [1, 2])
117 125 end
118 126
119 127 context "by deleting membership" do
120 128 should "prune watchers" do
121 129 assert_difference 'Watcher.count', -4 do
122 130 @member.destroy
123 131 end
124 132 end
125 133 end
126 134
127 135 context "by updating roles" do
128 136 should "prune watchers" do
129 137 Role.find(2).remove_permission! :view_wiki_pages
130 138 member = Member.first(:order => 'id desc')
131 139 assert_difference 'Watcher.count', -2 do
132 140 member.role_ids = [2]
133 141 member.save
134 142 end
135 143 assert !Message.find(7).watched_by?(@user)
136 144 end
137 145 end
138 146 end
139 147
140 148 context "of group" do
141 149 setup do
142 150 group = Group.find(10)
143 151 @member = Member.create!(:project => Project.find(2), :principal => group, :role_ids => [1, 2])
144 152 group.users << User.find(9)
145 153 end
146 154
147 155 context "by deleting membership" do
148 156 should "prune watchers" do
149 157 assert_difference 'Watcher.count', -4 do
150 158 @member.destroy
151 159 end
152 160 end
153 161 end
154 162
155 163 context "by updating roles" do
156 164 should "prune watchers" do
157 165 Role.find(2).remove_permission! :view_wiki_pages
158 166 assert_difference 'Watcher.count', -2 do
159 167 @member.role_ids = [2]
160 168 @member.save
161 169 end
162 170 end
163 171 end
164 172 end
165 173 end
166 174 end
General Comments 0
You need to be logged in to leave comments. Login now