Chris@0
|
1 # Redmine - project management software
|
Chris@1494
|
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
|
Chris@0
|
3 #
|
Chris@0
|
4 # This program is free software; you can redistribute it and/or
|
Chris@0
|
5 # modify it under the terms of the GNU General Public License
|
Chris@0
|
6 # as published by the Free Software Foundation; either version 2
|
Chris@0
|
7 # of the License, or (at your option) any later version.
|
Chris@909
|
8 #
|
Chris@0
|
9 # This program is distributed in the hope that it will be useful,
|
Chris@0
|
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
|
Chris@0
|
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
Chris@0
|
12 # GNU General Public License for more details.
|
Chris@909
|
13 #
|
Chris@0
|
14 # You should have received a copy of the GNU General Public License
|
Chris@0
|
15 # along with this program; if not, write to the Free Software
|
Chris@0
|
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
Chris@0
|
17
|
Chris@119
|
18 require File.expand_path('../../../test_helper', __FILE__)
|
Chris@0
|
19
|
Chris@909
|
20 class SortHelperTest < ActionView::TestCase
|
Chris@0
|
21 include SortHelper
|
Chris@1464
|
22 include Redmine::I18n
|
Chris@1115
|
23 include ERB::Util
|
Chris@909
|
24
|
Chris@0
|
25 def setup
|
Chris@0
|
26 @session = nil
|
Chris@0
|
27 @sort_param = nil
|
Chris@0
|
28 end
|
Chris@909
|
29
|
Chris@0
|
30 def test_default_sort_clause_with_array
|
Chris@0
|
31 sort_init 'attr1', 'desc'
|
Chris@0
|
32 sort_update(['attr1', 'attr2'])
|
Chris@0
|
33
|
Chris@1464
|
34 assert_equal ['attr1 DESC'], sort_clause
|
Chris@0
|
35 end
|
Chris@909
|
36
|
Chris@0
|
37 def test_default_sort_clause_with_hash
|
Chris@0
|
38 sort_init 'attr1', 'desc'
|
Chris@0
|
39 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
|
Chris@0
|
40
|
Chris@1464
|
41 assert_equal ['table1.attr1 DESC'], sort_clause
|
Chris@0
|
42 end
|
Chris@909
|
43
|
Chris@0
|
44 def test_default_sort_clause_with_multiple_columns
|
Chris@0
|
45 sort_init 'attr1', 'desc'
|
Chris@0
|
46 sort_update({'attr1' => ['table1.attr1', 'table1.attr2'], 'attr2' => 'table2.attr2'})
|
Chris@0
|
47
|
Chris@1464
|
48 assert_equal ['table1.attr1 DESC', 'table1.attr2 DESC'], sort_clause
|
Chris@0
|
49 end
|
Chris@909
|
50
|
Chris@0
|
51 def test_params_sort
|
Chris@0
|
52 @sort_param = 'attr1,attr2:desc'
|
Chris@909
|
53
|
Chris@0
|
54 sort_init 'attr1', 'desc'
|
Chris@0
|
55 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
|
Chris@0
|
56
|
Chris@1464
|
57 assert_equal ['table1.attr1', 'table2.attr2 DESC'], sort_clause
|
Chris@0
|
58 assert_equal 'attr1,attr2:desc', @session['foo_bar_sort']
|
Chris@0
|
59 end
|
Chris@909
|
60
|
Chris@0
|
61 def test_invalid_params_sort
|
Chris@0
|
62 @sort_param = 'invalid_key'
|
Chris@909
|
63
|
Chris@0
|
64 sort_init 'attr1', 'desc'
|
Chris@0
|
65 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
|
Chris@0
|
66
|
Chris@1464
|
67 assert_equal ['table1.attr1 DESC'], sort_clause
|
Chris@0
|
68 assert_equal 'attr1:desc', @session['foo_bar_sort']
|
Chris@0
|
69 end
|
Chris@909
|
70
|
Chris@0
|
71 def test_invalid_order_params_sort
|
Chris@0
|
72 @sort_param = 'attr1:foo:bar,attr2'
|
Chris@909
|
73
|
Chris@0
|
74 sort_init 'attr1', 'desc'
|
Chris@0
|
75 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
|
Chris@0
|
76
|
Chris@1464
|
77 assert_equal ['table1.attr1', 'table2.attr2'], sort_clause
|
Chris@0
|
78 assert_equal 'attr1,attr2', @session['foo_bar_sort']
|
Chris@0
|
79 end
|
Chris@909
|
80
|
Chris@0
|
81 private
|
Chris@909
|
82
|
Chris@0
|
83 def controller_name; 'foo'; end
|
Chris@0
|
84 def action_name; 'bar'; end
|
Chris@0
|
85 def params; {:sort => @sort_param}; end
|
Chris@0
|
86 def session; @session ||= {}; end
|
Chris@0
|
87 end
|