summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2009-07-18 09:46:20 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2009-07-18 09:46:20 +0000
commitbf0ddc2886f4c0b9629a36686f168051615564a9 (patch)
tree101bd920726d0fab07104884515f02af3ad1d31c
parent36d8f3519246898c402683a1b1575660f52de260 (diff)
downloadredmine-bf0ddc2886f4c0b9629a36686f168051615564a9.tar.gz
redmine-bf0ddc2886f4c0b9629a36686f168051615564a9.zip
Fixes artefacts in truncated search results (#3622).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2822 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/helpers/search_helper.rb3
-rw-r--r--test/unit/helpers/search_helper_test.rb45
2 files changed, 47 insertions, 1 deletions
diff --git a/app/helpers/search_helper.rb b/app/helpers/search_helper.rb
index 32ff16f67..640b5a907 100644
--- a/app/helpers/search_helper.rb
+++ b/app/helpers/search_helper.rb
@@ -27,8 +27,9 @@ module SearchHelper
result << '...'
break
end
+ words = words.mb_chars
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
t = (tokens.index(words.downcase) || 0) % 4
result << content_tag('span', h(words), :class => "highlight token-#{t}")
diff --git a/test/unit/helpers/search_helper_test.rb b/test/unit/helpers/search_helper_test.rb
new file mode 100644
index 000000000..6616fcb1a
--- /dev/null
+++ b/test/unit/helpers/search_helper_test.rb
@@ -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