##// END OF EJS Templates
remove duplicate fixtures from test/unit/member_test.rb...
Toshi MARUYAMA -
r7407:ca7051aea923
parent child
Show More
@@ -1,151 +1,150
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 :issues, :issue_statuses, :issue_categories,
33 32 :messages,
34 33 :wikis, :wiki_pages, :wiki_contents, :wiki_content_versions,
35 34 :boards
36 35
37 36 def setup
38 37 @jsmith = Member.find(1)
39 38 end
40 39
41 40 def test_create
42 41 member = Member.new(:project_id => 1, :user_id => 4, :role_ids => [1, 2])
43 42 assert member.save
44 43 member.reload
45 44
46 45 assert_equal 2, member.roles.size
47 46 assert_equal Role.find(1), member.roles.sort.first
48 47 end
49 48
50 49 def test_update
51 50 assert_equal "eCookbook", @jsmith.project.name
52 51 assert_equal "Manager", @jsmith.roles.first.name
53 52 assert_equal "jsmith", @jsmith.user.login
54 53
55 54 @jsmith.mail_notification = !@jsmith.mail_notification
56 55 assert @jsmith.save
57 56 end
58 57
59 58 def test_update_roles
60 59 assert_equal 1, @jsmith.roles.size
61 60 @jsmith.role_ids = [1, 2]
62 61 assert @jsmith.save
63 62 assert_equal 2, @jsmith.reload.roles.size
64 63 end
65 64
66 65 def test_validate
67 66 member = Member.new(:project_id => 1, :user_id => 2, :role_ids => [2])
68 67 # same use can't have more than one membership for a project
69 68 assert !member.save
70 69
71 70 member = Member.new(:project_id => 1, :user_id => 2, :role_ids => [])
72 71 # must have one role at least
73 72 assert !member.save
74 73 end
75 74
76 75 def test_destroy
77 76 assert_difference 'Member.count', -1 do
78 77 assert_difference 'MemberRole.count', -1 do
79 78 @jsmith.destroy
80 79 end
81 80 end
82 81
83 82 assert_raise(ActiveRecord::RecordNotFound) { Member.find(@jsmith.id) }
84 83 end
85 84
86 85 context "removing permissions" do
87 86 setup do
88 87 Watcher.delete_all("user_id = 9")
89 88 user = User.find(9)
90 89 # public
91 90 Watcher.create!(:watchable => Issue.find(1), :user => user)
92 91 # private
93 92 Watcher.create!(:watchable => Issue.find(4), :user => user)
94 93 Watcher.create!(:watchable => Message.find(7), :user => user)
95 94 Watcher.create!(:watchable => Wiki.find(2), :user => user)
96 95 Watcher.create!(:watchable => WikiPage.find(3), :user => user)
97 96 end
98 97
99 98 context "of user" do
100 99 setup do
101 100 @member = Member.create!(:project => Project.find(2), :principal => User.find(9), :role_ids => [1, 2])
102 101 end
103 102
104 103 context "by deleting membership" do
105 104 should "prune watchers" do
106 105 assert_difference 'Watcher.count', -4 do
107 106 @member.destroy
108 107 end
109 108 end
110 109 end
111 110
112 111 context "by updating roles" do
113 112 should "prune watchers" do
114 113 Role.find(2).remove_permission! :view_wiki_pages
115 114 member = Member.first(:order => 'id desc')
116 115 assert_difference 'Watcher.count', -2 do
117 116 member.role_ids = [2]
118 117 member.save
119 118 end
120 119 assert !Message.find(7).watched_by?(@user)
121 120 end
122 121 end
123 122 end
124 123
125 124 context "of group" do
126 125 setup do
127 126 group = Group.find(10)
128 127 @member = Member.create!(:project => Project.find(2), :principal => group, :role_ids => [1, 2])
129 128 group.users << User.find(9)
130 129 end
131 130
132 131 context "by deleting membership" do
133 132 should "prune watchers" do
134 133 assert_difference 'Watcher.count', -4 do
135 134 @member.destroy
136 135 end
137 136 end
138 137 end
139 138
140 139 context "by updating roles" do
141 140 should "prune watchers" do
142 141 Role.find(2).remove_permission! :view_wiki_pages
143 142 assert_difference 'Watcher.count', -2 do
144 143 @member.role_ids = [2]
145 144 @member.save
146 145 end
147 146 end
148 147 end
149 148 end
150 149 end
151 150 end
General Comments 0
You need to be logged in to leave comments. Login now