annotate test/unit/helpers/sort_helper_test.rb @ 8:0c83d98252d9 yuya

* Add custom repo prefix and proper auth realm, remove auth cache (seems like an unwise feature), pass DB handle around, various other bits of tidying
author Chris Cannam
date Thu, 12 Aug 2010 15:31:37 +0100
parents 513646585e45
children af80e5618e9b
rev   line source
Chris@0 1 # Redmine - project management software
Chris@0 2 # Copyright (C) 2006-2009 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@0 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@0 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@0 18 require File.dirname(__FILE__) + '/../../test_helper'
Chris@0 19
Chris@0 20 class SortHelperTest < HelperTestCase
Chris@0 21 include SortHelper
Chris@0 22
Chris@0 23 def setup
Chris@0 24 @session = nil
Chris@0 25 @sort_param = nil
Chris@0 26 end
Chris@0 27
Chris@0 28 def test_default_sort_clause_with_array
Chris@0 29 sort_init 'attr1', 'desc'
Chris@0 30 sort_update(['attr1', 'attr2'])
Chris@0 31
Chris@0 32 assert_equal 'attr1 DESC', sort_clause
Chris@0 33 end
Chris@0 34
Chris@0 35 def test_default_sort_clause_with_hash
Chris@0 36 sort_init 'attr1', 'desc'
Chris@0 37 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
Chris@0 38
Chris@0 39 assert_equal 'table1.attr1 DESC', sort_clause
Chris@0 40 end
Chris@0 41
Chris@0 42 def test_default_sort_clause_with_multiple_columns
Chris@0 43 sort_init 'attr1', 'desc'
Chris@0 44 sort_update({'attr1' => ['table1.attr1', 'table1.attr2'], 'attr2' => 'table2.attr2'})
Chris@0 45
Chris@0 46 assert_equal 'table1.attr1 DESC, table1.attr2 DESC', sort_clause
Chris@0 47 end
Chris@0 48
Chris@0 49 def test_params_sort
Chris@0 50 @sort_param = 'attr1,attr2:desc'
Chris@0 51
Chris@0 52 sort_init 'attr1', 'desc'
Chris@0 53 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
Chris@0 54
Chris@0 55 assert_equal 'table1.attr1, table2.attr2 DESC', sort_clause
Chris@0 56 assert_equal 'attr1,attr2:desc', @session['foo_bar_sort']
Chris@0 57 end
Chris@0 58
Chris@0 59 def test_invalid_params_sort
Chris@0 60 @sort_param = 'invalid_key'
Chris@0 61
Chris@0 62 sort_init 'attr1', 'desc'
Chris@0 63 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
Chris@0 64
Chris@0 65 assert_equal 'table1.attr1 DESC', sort_clause
Chris@0 66 assert_equal 'attr1:desc', @session['foo_bar_sort']
Chris@0 67 end
Chris@0 68
Chris@0 69 def test_invalid_order_params_sort
Chris@0 70 @sort_param = 'attr1:foo:bar,attr2'
Chris@0 71
Chris@0 72 sort_init 'attr1', 'desc'
Chris@0 73 sort_update({'attr1' => 'table1.attr1', 'attr2' => 'table2.attr2'})
Chris@0 74
Chris@0 75 assert_equal 'table1.attr1, table2.attr2', sort_clause
Chris@0 76 assert_equal 'attr1,attr2', @session['foo_bar_sort']
Chris@0 77 end
Chris@0 78
Chris@0 79 private
Chris@0 80
Chris@0 81 def controller_name; 'foo'; end
Chris@0 82 def action_name; 'bar'; end
Chris@0 83 def params; {:sort => @sort_param}; end
Chris@0 84 def session; @session ||= {}; end
Chris@0 85 end