Fixes artefacts in truncated search results (#3622).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2822 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
36d8f35192
commit
bf0ddc2886
@ -27,8 +27,9 @@ module SearchHelper
|
|||||||
result << '...'
|
result << '...'
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
|
words = words.mb_chars
|
||||||
if i.even?
|
if i.even?
|
||||||
result << h(words.length > 100 ? "#{words[0..44]} ... #{words[-45..-1]}" : words)
|
result << h(words.length > 100 ? "#{words.slice(0..44)} ... #{words.slice(-45..-1)}" : words)
|
||||||
else
|
else
|
||||||
t = (tokens.index(words.downcase) || 0) % 4
|
t = (tokens.index(words.downcase) || 0) % 4
|
||||||
result << content_tag('span', h(words), :class => "highlight token-#{t}")
|
result << content_tag('span', h(words), :class => "highlight token-#{t}")
|
||||||
|
45
test/unit/helpers/search_helper_test.rb
Normal file
45
test/unit/helpers/search_helper_test.rb
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
# Redmine - project management software
|
||||||
|
# Copyright (C) 2006-2009 Jean-Philippe Lang
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License
|
||||||
|
# as published by the Free Software Foundation; either version 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
|
require File.dirname(__FILE__) + '/../../test_helper'
|
||||||
|
|
||||||
|
class SearchHelperTest < HelperTestCase
|
||||||
|
include SearchHelper
|
||||||
|
|
||||||
|
def test_highlight_single_token
|
||||||
|
assert_equal 'This is a <span class="highlight token-0">token</span>.',
|
||||||
|
highlight_tokens('This is a token.', %w(token))
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_highlight_multiple_tokens
|
||||||
|
assert_equal 'This is a <span class="highlight token-0">token</span> and <span class="highlight token-1">another</span> <span class="highlight token-0">token</span>.',
|
||||||
|
highlight_tokens('This is a token and another token.', %w(token another))
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_highlight_should_not_exceed_maximum_length
|
||||||
|
s = (('1234567890' * 100) + ' token ') * 100
|
||||||
|
r = highlight_tokens(s, %w(token))
|
||||||
|
assert r.include?('<span class="highlight token-0">token</span>')
|
||||||
|
assert r.length <= 1300
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_highlight_multibyte
|
||||||
|
s = ('й' * 200) + ' token ' + ('й' * 200)
|
||||||
|
r = highlight_tokens(s, %w(token))
|
||||||
|
assert_equal ('й' * 45) + ' ... ' + ('й' * 44) + ' <span class="highlight token-0">token</span> ' + ('й' * 44) + ' ... ' + ('й' * 45), r
|
||||||
|
end
|
||||||
|
end
|
Loading…
x
Reference in New Issue
Block a user