Fixed: Inline images don't work if file name has upper case letters or if image is in BMP format (#2102).

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@1958 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2008-10-28 10:43:34 +00:00
parent 6cd4f0c07e
commit 0f1787ea0d
2 changed files with 12 additions and 2 deletions

View File

@ -247,7 +247,7 @@ module ApplicationHelper
if attachments if attachments
attachments = attachments.sort_by(&:created_on).reverse attachments = attachments.sort_by(&:created_on).reverse
text = text.gsub(/!((\<|\=|\>)?(\([^\)]+\))?(\[[^\]]+\])?(\{[^\}]+\})?)(\S+\.(gif|jpg|jpeg|png))!/) do |m| text = text.gsub(/!((\<|\=|\>)?(\([^\)]+\))?(\[[^\]]+\])?(\{[^\}]+\})?)(\S+\.(bmp|gif|jpg|jpeg|png))!/i) do |m|
style = $1 style = $1
filename = $6 filename = $6
rf = Regexp.new(Regexp.escape(filename), Regexp::IGNORECASE) rf = Regexp.new(Regexp.escape(filename), Regexp::IGNORECASE)

View File

@ -24,7 +24,8 @@ class ApplicationHelperTest < HelperTestCase
:repositories, :changesets, :repositories, :changesets,
:trackers, :issue_statuses, :issues, :versions, :documents, :trackers, :issue_statuses, :issues, :versions, :documents,
:wikis, :wiki_pages, :wiki_contents, :wikis, :wiki_pages, :wiki_contents,
:boards, :messages :boards, :messages,
:attachments
def setup def setup
super super
@ -70,6 +71,15 @@ class ApplicationHelperTest < HelperTestCase
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) } to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
end end
def test_attached_images
to_test = {
'Inline image: !logo.gif!' => 'Inline image: <img src="/attachments/download/3" title="This is a logo" alt="This is a logo" />',
'Inline image: !logo.GIF!' => 'Inline image: <img src="/attachments/download/3" title="This is a logo" alt="This is a logo" />'
}
attachments = Attachment.find(:all)
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text, :attachments => attachments) }
end
def test_textile_external_links def test_textile_external_links
to_test = { to_test = {
'This is a "link":http://foo.bar' => 'This is a <a href="http://foo.bar" class="external">link</a>', 'This is a "link":http://foo.bar' => 'This is a <a href="http://foo.bar" class="external">link</a>',