fix malformed issues csv encoding in case of unable to convert (#8549)
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@7822 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
dde0de8cc5
commit
eb498a86ac
|
@ -264,7 +264,6 @@ module IssuesHelper
|
||||||
end
|
end
|
||||||
|
|
||||||
def issues_to_csv(issues, project = nil)
|
def issues_to_csv(issues, project = nil)
|
||||||
ic = Iconv.new(l(:general_csv_encoding), 'UTF-8')
|
|
||||||
decimal_separator = l(:general_csv_decimal_separator)
|
decimal_separator = l(:general_csv_decimal_separator)
|
||||||
export = FCSV.generate(:col_sep => l(:general_csv_separator)) do |csv|
|
export = FCSV.generate(:col_sep => l(:general_csv_separator)) do |csv|
|
||||||
# csv header fields
|
# csv header fields
|
||||||
|
@ -292,7 +291,9 @@ module IssuesHelper
|
||||||
custom_fields.each {|f| headers << f.name}
|
custom_fields.each {|f| headers << f.name}
|
||||||
# Description in the last column
|
# Description in the last column
|
||||||
headers << l(:field_description)
|
headers << l(:field_description)
|
||||||
csv << headers.collect {|c| begin; ic.iconv(c.to_s); rescue; c.to_s; end }
|
csv << headers.collect {|c| Redmine::CodesetUtil.from_utf8(
|
||||||
|
c.to_s,
|
||||||
|
l(:general_csv_encoding) ) }
|
||||||
# csv lines
|
# csv lines
|
||||||
issues.each do |issue|
|
issues.each do |issue|
|
||||||
fields = [issue.id,
|
fields = [issue.id,
|
||||||
|
@ -315,7 +316,9 @@ module IssuesHelper
|
||||||
]
|
]
|
||||||
custom_fields.each {|f| fields << show_value(issue.custom_value_for(f)) }
|
custom_fields.each {|f| fields << show_value(issue.custom_value_for(f)) }
|
||||||
fields << issue.description
|
fields << issue.description
|
||||||
csv << fields.collect {|c| begin; ic.iconv(c.to_s); rescue; c.to_s; end }
|
csv << fields.collect {|c| Redmine::CodesetUtil.from_utf8(
|
||||||
|
c.to_s,
|
||||||
|
l(:general_csv_encoding) ) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
export
|
export
|
||||||
|
|
|
@ -324,6 +324,41 @@ class IssuesControllerTest < ActionController::TestCase
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_index_csv_cannot_convert_should_be_replaced_big_5
|
||||||
|
with_settings :default_language => "zh-TW" do
|
||||||
|
str_utf8 = "\xe4\xbb\xa5\xe5\x86\x85"
|
||||||
|
if str_utf8.respond_to?(:force_encoding)
|
||||||
|
str_utf8.force_encoding('UTF-8')
|
||||||
|
end
|
||||||
|
issue = Issue.new(:project_id => 1, :tracker_id => 1, :author_id => 3,
|
||||||
|
:status_id => 1, :priority => IssuePriority.all.first,
|
||||||
|
:subject => str_utf8)
|
||||||
|
assert issue.save
|
||||||
|
|
||||||
|
get :index, :project_id => 1,
|
||||||
|
:f => ['subject'],
|
||||||
|
:op => '=', :values => [str_utf8],
|
||||||
|
:format => 'csv'
|
||||||
|
assert_equal 'text/csv', @response.content_type
|
||||||
|
lines = @response.body.chomp.split("\n")
|
||||||
|
s1 = "\xaa\xac\xbaA"
|
||||||
|
if str_utf8.respond_to?(:force_encoding)
|
||||||
|
s1.force_encoding('Big5')
|
||||||
|
end
|
||||||
|
assert lines[0].include?(s1)
|
||||||
|
s2 = lines[1].split(",")[5]
|
||||||
|
if s1.respond_to?(:force_encoding)
|
||||||
|
s3 = "\xa5H?"
|
||||||
|
s3.force_encoding('Big5')
|
||||||
|
assert_equal s3, s2
|
||||||
|
elsif RUBY_PLATFORM == 'java'
|
||||||
|
assert_equal "??", s2
|
||||||
|
else
|
||||||
|
assert_equal "\xa5H???", s2
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def test_index_pdf
|
def test_index_pdf
|
||||||
get :index, :format => 'pdf'
|
get :index, :format => 'pdf'
|
||||||
assert_response :success
|
assert_response :success
|
||||||
|
|
Loading…
Reference in New Issue