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:
Jean-Philippe Lang 2008-01-21 18:52:45 +00:00
parent c65ab7c0f2
commit dad5f6d403
3 changed files with 34 additions and 3 deletions

View File

@ -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

View File

@ -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"

View File

@ -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])}')"