Fixed search with all words (broken in r994).
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1092 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
c65ab7c0f2
commit
dad5f6d403
|
@ -22,7 +22,7 @@ issues_002:
|
||||||
id: 2
|
id: 2
|
||||||
fixed_version_id:
|
fixed_version_id:
|
||||||
category_id:
|
category_id:
|
||||||
description: Ingredients should be classified by categories
|
description: Ingredients of the recipe should be classified by categories
|
||||||
tracker_id: 2
|
tracker_id: 2
|
||||||
assigned_to_id: 3
|
assigned_to_id: 3
|
||||||
author_id: 2
|
author_id: 2
|
||||||
|
|
|
@ -5,7 +5,7 @@ require 'search_controller'
|
||||||
class SearchController; def rescue_action(e) raise e end; end
|
class SearchController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class SearchControllerTest < Test::Unit::TestCase
|
class SearchControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :issues, :custom_fields, :custom_values
|
fixtures :projects, :enabled_modules, :issues, :custom_fields, :custom_values
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = SearchController.new
|
@controller = SearchController.new
|
||||||
|
@ -47,6 +47,37 @@ class SearchControllerTest < Test::Unit::TestCase
|
||||||
assert results.include?(Issue.find(3))
|
assert results.include?(Issue.find(3))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_search_all_words
|
||||||
|
# 'all words' is on by default
|
||||||
|
get :index, :id => 1, :q => 'recipe updating saving'
|
||||||
|
results = assigns(:results)
|
||||||
|
assert_not_nil results
|
||||||
|
assert_equal 1, results.size
|
||||||
|
assert results.include?(Issue.find(3))
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_search_one_of_the_words
|
||||||
|
get :index, :id => 1, :q => 'recipe updating saving', :submit => 'Search'
|
||||||
|
results = assigns(:results)
|
||||||
|
assert_not_nil results
|
||||||
|
assert_equal 3, results.size
|
||||||
|
assert results.include?(Issue.find(3))
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_search_titles_only_without_result
|
||||||
|
get :index, :id => 1, :q => 'recipe updating saving', :all_words => '1', :titles_only => '1', :submit => 'Search'
|
||||||
|
results = assigns(:results)
|
||||||
|
assert_not_nil results
|
||||||
|
assert_equal 0, results.size
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_search_titles_only
|
||||||
|
get :index, :id => 1, :q => 'recipe', :titles_only => '1', :submit => 'Search'
|
||||||
|
results = assigns(:results)
|
||||||
|
assert_not_nil results
|
||||||
|
assert_equal 2, results.size
|
||||||
|
end
|
||||||
|
|
||||||
def test_quick_jump_to_issue
|
def test_quick_jump_to_issue
|
||||||
# issue of a public project
|
# issue of a public project
|
||||||
get :index, :q => "3"
|
get :index, :q => "3"
|
||||||
|
|
|
@ -85,7 +85,7 @@ module Redmine
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
sql = ([token_clauses.join(' OR ')] * tokens.size).join(options[:all_words] ? ' AND ' : ' OR ')
|
sql = (['(' + token_clauses.join(' OR ') + ')'] * tokens.size).join(options[:all_words] ? ' AND ' : ' OR ')
|
||||||
|
|
||||||
if options[:offset]
|
if options[:offset]
|
||||||
sql = "(#{sql}) AND (#{searchable_options[:date_column]} " + (options[:before] ? '<' : '>') + "'#{connection.quoted_date(options[:offset])}')"
|
sql = "(#{sql}) AND (#{searchable_options[:date_column]} " + (options[:before] ? '<' : '>') + "'#{connection.quoted_date(options[:offset])}')"
|
||||||
|
|
Loading…
Reference in New Issue