##// END OF EJS Templates
Simplifies Principal.active scope (status defaults to 1 for groups)....
Jean-Philippe Lang -
r8626:0154d7477b53
parent child
Show More
@@ -1,62 +1,62
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 class Principal < ActiveRecord::Base
18 class Principal < ActiveRecord::Base
19 set_table_name "#{table_name_prefix}users#{table_name_suffix}"
19 set_table_name "#{table_name_prefix}users#{table_name_suffix}"
20
20
21 has_many :members, :foreign_key => 'user_id', :dependent => :destroy
21 has_many :members, :foreign_key => 'user_id', :dependent => :destroy
22 has_many :memberships, :class_name => 'Member', :foreign_key => 'user_id', :include => [ :project, :roles ], :conditions => "#{Project.table_name}.status=#{Project::STATUS_ACTIVE}", :order => "#{Project.table_name}.name"
22 has_many :memberships, :class_name => 'Member', :foreign_key => 'user_id', :include => [ :project, :roles ], :conditions => "#{Project.table_name}.status=#{Project::STATUS_ACTIVE}", :order => "#{Project.table_name}.name"
23 has_many :projects, :through => :memberships
23 has_many :projects, :through => :memberships
24 has_many :issue_categories, :foreign_key => 'assigned_to_id', :dependent => :nullify
24 has_many :issue_categories, :foreign_key => 'assigned_to_id', :dependent => :nullify
25
25
26 # Groups and active users
26 # Groups and active users
27 named_scope :active, :conditions => "#{Principal.table_name}.type='Group' OR (#{Principal.table_name}.type='User' AND #{Principal.table_name}.status = 1)"
27 named_scope :active, :conditions => "#{Principal.table_name}.status = 1"
28
28
29 named_scope :like, lambda {|q|
29 named_scope :like, lambda {|q|
30 s = "%#{q.to_s.strip.downcase}%"
30 s = "%#{q.to_s.strip.downcase}%"
31 {:conditions => ["LOWER(login) LIKE :s OR LOWER(firstname) LIKE :s OR LOWER(lastname) LIKE :s OR LOWER(mail) LIKE :s", {:s => s}],
31 {:conditions => ["LOWER(login) LIKE :s OR LOWER(firstname) LIKE :s OR LOWER(lastname) LIKE :s OR LOWER(mail) LIKE :s", {:s => s}],
32 :order => 'type, login, lastname, firstname, mail'
32 :order => 'type, login, lastname, firstname, mail'
33 }
33 }
34 }
34 }
35
35
36 before_create :set_default_empty_values
36 before_create :set_default_empty_values
37
37
38 def name(formatter = nil)
38 def name(formatter = nil)
39 to_s
39 to_s
40 end
40 end
41
41
42 def <=>(principal)
42 def <=>(principal)
43 if self.class.name == principal.class.name
43 if self.class.name == principal.class.name
44 self.to_s.downcase <=> principal.to_s.downcase
44 self.to_s.downcase <=> principal.to_s.downcase
45 else
45 else
46 # groups after users
46 # groups after users
47 principal.class.name <=> self.class.name
47 principal.class.name <=> self.class.name
48 end
48 end
49 end
49 end
50
50
51 protected
51 protected
52
52
53 # Make sure we don't try to insert NULL values (see #4632)
53 # Make sure we don't try to insert NULL values (see #4632)
54 def set_default_empty_values
54 def set_default_empty_values
55 self.login ||= ''
55 self.login ||= ''
56 self.hashed_password ||= ''
56 self.hashed_password ||= ''
57 self.firstname ||= ''
57 self.firstname ||= ''
58 self.lastname ||= ''
58 self.lastname ||= ''
59 self.mail ||= ''
59 self.mail ||= ''
60 true
60 true
61 end
61 end
62 end
62 end
@@ -1,66 +1,74
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 require File.expand_path('../../test_helper', __FILE__)
18 require File.expand_path('../../test_helper', __FILE__)
19
19
20 class PrincipalTest < ActiveSupport::TestCase
20 class PrincipalTest < ActiveSupport::TestCase
21
21
22 def test_active_scope_should_return_groups_and_active_users
23 result = Principal.active.all
24 assert_include Group.first, result
25 assert_not_nil result.detect {|p| p.is_a?(User)}
26 assert_nil result.detect {|p| p.is_a?(User) && !p.active?}
27 assert_nil result.detect {|p| p.is_a?(AnonymousUser)}
28 end
29
22 context "#like" do
30 context "#like" do
23 setup do
31 setup do
24 Principal.generate!(:login => 'login')
32 Principal.generate!(:login => 'login')
25 Principal.generate!(:login => 'login2')
33 Principal.generate!(:login => 'login2')
26
34
27 Principal.generate!(:firstname => 'firstname')
35 Principal.generate!(:firstname => 'firstname')
28 Principal.generate!(:firstname => 'firstname2')
36 Principal.generate!(:firstname => 'firstname2')
29
37
30 Principal.generate!(:lastname => 'lastname')
38 Principal.generate!(:lastname => 'lastname')
31 Principal.generate!(:lastname => 'lastname2')
39 Principal.generate!(:lastname => 'lastname2')
32
40
33 Principal.generate!(:mail => 'mail@example.com')
41 Principal.generate!(:mail => 'mail@example.com')
34 Principal.generate!(:mail => 'mail2@example.com')
42 Principal.generate!(:mail => 'mail2@example.com')
35 end
43 end
36
44
37 should "search login" do
45 should "search login" do
38 results = Principal.like('login')
46 results = Principal.like('login')
39
47
40 assert_equal 2, results.count
48 assert_equal 2, results.count
41 assert results.all? {|u| u.login.match(/login/) }
49 assert results.all? {|u| u.login.match(/login/) }
42 end
50 end
43
51
44 should "search firstname" do
52 should "search firstname" do
45 results = Principal.like('firstname')
53 results = Principal.like('firstname')
46
54
47 assert_equal 2, results.count
55 assert_equal 2, results.count
48 assert results.all? {|u| u.firstname.match(/firstname/) }
56 assert results.all? {|u| u.firstname.match(/firstname/) }
49 end
57 end
50
58
51 should "search lastname" do
59 should "search lastname" do
52 results = Principal.like('lastname')
60 results = Principal.like('lastname')
53
61
54 assert_equal 2, results.count
62 assert_equal 2, results.count
55 assert results.all? {|u| u.lastname.match(/lastname/) }
63 assert results.all? {|u| u.lastname.match(/lastname/) }
56 end
64 end
57
65
58 should "search mail" do
66 should "search mail" do
59 results = Principal.like('mail')
67 results = Principal.like('mail')
60
68
61 assert_equal 2, results.count
69 assert_equal 2, results.count
62 assert results.all? {|u| u.mail.match(/mail/) }
70 assert results.all? {|u| u.mail.match(/mail/) }
63 end
71 end
64 end
72 end
65
73
66 end
74 end
General Comments 0
You need to be logged in to leave comments. Login now