summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/functional/issues_controller_test.rb38
-rw-r--r--test/test_helper.rb4
-rw-r--r--test/unit/query_test.rb16
-rw-r--r--test/unit/user_test.rb24
4 files changed, 75 insertions, 7 deletions
diff --git a/test/functional/issues_controller_test.rb b/test/functional/issues_controller_test.rb
index 8044ead12..ff89e5a85 100644
--- a/test/functional/issues_controller_test.rb
+++ b/test/functional/issues_controller_test.rb
@@ -276,11 +276,6 @@ class IssuesControllerTest < ActionController::TestCase
assert_response :success
end
- def test_index_sort_by_field_not_included_in_columns
- Setting.issue_list_default_columns = %w(subject author)
- get :index, :sort => 'tracker'
- end
-
def test_index_csv
get :index, :format => 'csv'
assert_response :success
@@ -421,10 +416,43 @@ class IssuesControllerTest < ActionController::TestCase
assert !issues.empty?
assert_equal issues.sort {|a,b| a.tracker == b.tracker ? b.id <=> a.id : a.tracker <=> b.tracker }.collect(&:id), issues.collect(&:id)
end
+
+ def test_index_sort_by_field_not_included_in_columns
+ Setting.issue_list_default_columns = %w(subject author)
+ get :index, :sort => 'tracker'
+ end
+
+ def test_index_sort_by_assigned_to
+ get :index, :sort => 'assigned_to'
+ assert_response :success
+ assignees = assigns(:issues).collect(&:assigned_to).compact
+ assert_equal assignees.sort, assignees
+ end
+
+ def test_index_sort_by_assigned_to_desc
+ get :index, :sort => 'assigned_to:desc'
+ assert_response :success
+ assignees = assigns(:issues).collect(&:assigned_to).compact
+ assert_equal assignees.sort.reverse, assignees
+ end
+
+ def test_index_group_by_assigned_to
+ get :index, :group_by => 'assigned_to', :sort => 'priority'
+ assert_response :success
+ end
def test_index_sort_by_author
get :index, :sort => 'author'
assert_response :success
+ authors = assigns(:issues).collect(&:author)
+ assert_equal authors.sort, authors
+ end
+
+ def test_index_sort_by_author_desc
+ get :index, :sort => 'author:desc'
+ assert_response :success
+ authors = assigns(:issues).collect(&:author)
+ assert_equal authors.sort.reverse, authors
end
def test_index_group_by_author
diff --git a/test/test_helper.rb b/test/test_helper.rb
index 78b83c06d..dcac221d4 100644
--- a/test/test_helper.rb
+++ b/test/test_helper.rb
@@ -98,11 +98,11 @@ class ActiveSupport::TestCase
end
def with_settings(options, &block)
- saved_settings = options.keys.inject({}) {|h, k| h[k] = Setting[k].dup; h}
+ saved_settings = options.keys.inject({}) {|h, k| h[k] = Setting[k].is_a?(Symbol) ? Setting[k] : Setting[k].dup; h}
options.each {|k, v| Setting[k] = v}
yield
ensure
- saved_settings.each {|k, v| Setting[k] = v}
+ saved_settings.each {|k, v| Setting[k] = v} if saved_settings
end
def change_user_password(login, new_password)
diff --git a/test/unit/query_test.rb b/test/unit/query_test.rb
index 6306e8721..e3f3c9249 100644
--- a/test/unit/query_test.rb
+++ b/test/unit/query_test.rb
@@ -443,6 +443,22 @@ class QueryTest < ActiveSupport::TestCase
assert_nil q.group_by_column
assert_nil q.group_by_statement
end
+
+ def test_sortable_columns_should_sort_assignees_according_to_user_format_setting
+ with_settings :user_format => 'lastname_coma_firstname' do
+ q = Query.new
+ assert q.sortable_columns.has_key?('assigned_to')
+ assert_equal %w(users.lastname users.firstname users.id), q.sortable_columns['assigned_to']
+ end
+ end
+
+ def test_sortable_columns_should_sort_authors_according_to_user_format_setting
+ with_settings :user_format => 'lastname_coma_firstname' do
+ q = Query.new
+ assert q.sortable_columns.has_key?('author')
+ assert_equal %w(authors.lastname authors.firstname authors.id), q.sortable_columns['author']
+ end
+ end
def test_default_sort
q = Query.new
diff --git a/test/unit/user_test.rb b/test/unit/user_test.rb
index 5f7150d6e..a772d0079 100644
--- a/test/unit/user_test.rb
+++ b/test/unit/user_test.rb
@@ -397,6 +397,30 @@ class UserTest < ActiveSupport::TestCase
Setting.user_format = :username
assert_equal 'jsmith', @jsmith.reload.name
end
+
+ def test_fields_for_order_statement_should_return_fields_according_user_format_setting
+ with_settings :user_format => 'lastname_coma_firstname' do
+ assert_equal ['users.lastname', 'users.firstname', 'users.id'], User.fields_for_order_statement
+ end
+ end
+
+ def test_fields_for_order_statement_width_table_name_should_prepend_table_name
+ with_settings :user_format => 'lastname_firstname' do
+ assert_equal ['authors.lastname', 'authors.firstname', 'authors.id'], User.fields_for_order_statement('authors')
+ end
+ end
+
+ def test_fields_for_order_statement_with_blank_format_should_return_default
+ with_settings :user_format => '' do
+ assert_equal ['users.firstname', 'users.lastname', 'users.id'], User.fields_for_order_statement
+ end
+ end
+
+ def test_fields_for_order_statement_with_invalid_format_should_return_default
+ with_settings :user_format => 'foo' do
+ assert_equal ['users.firstname', 'users.lastname', 'users.id'], User.fields_for_order_statement
+ end
+ end
def test_lock
user = User.try_to_login("jsmith", "jsmith")