summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-11-16 08:10:53 +0000
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-11-16 08:10:53 +0000
commit4b5d50e40a4907cdbd4efa9100dbb51c7e534e3f (patch)
tree4c0a134bc813162c244cdbf890bd70eeea20c162
parent8433bbab69c6e18074383b73d820368f8bdddfbe (diff)
downloadredmine-4b5d50e40a4907cdbd4efa9100dbb51c7e534e3f.tar.gz
redmine-4b5d50e40a4907cdbd4efa9100dbb51c7e534e3f.zip
fix malformed time log csv encoding in case of unable to convert (#8549)
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@7819 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/helpers/timelog_helper.rb9
-rw-r--r--test/functional/timelog_controller_test.rb46
2 files changed, 52 insertions, 3 deletions
diff --git a/app/helpers/timelog_helper.rb b/app/helpers/timelog_helper.rb
index 65a23f89c..6b34e60b0 100644
--- a/app/helpers/timelog_helper.rb
+++ b/app/helpers/timelog_helper.rb
@@ -84,7 +84,6 @@ module TimelogHelper
end
def entries_to_csv(entries)
- ic = Iconv.new(l(:general_csv_encoding), 'UTF-8')
decimal_separator = l(:general_csv_decimal_separator)
custom_fields = TimeEntryCustomField.find(:all)
export = FCSV.generate(:col_sep => l(:general_csv_separator)) do |csv|
@@ -102,7 +101,9 @@ module TimelogHelper
# Export custom fields
headers += custom_fields.collect(&:name)
- 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
entries.each do |entry|
fields = [format_date(entry.spent_on),
@@ -117,7 +118,9 @@ module TimelogHelper
]
fields += custom_fields.collect {|f| show_value(entry.custom_value_for(f)) }
- 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
export
diff --git a/test/functional/timelog_controller_test.rb b/test/functional/timelog_controller_test.rb
index 6581d5bc3..c455d5496 100644
--- a/test/functional/timelog_controller_test.rb
+++ b/test/functional/timelog_controller_test.rb
@@ -368,4 +368,50 @@ class TimelogControllerTest < ActionController::TestCase
assert ar[0].include?(s1)
assert ar[1].include?(str_big5)
end
+
+ def test_csv_cannot_convert_should_be_replaced_big_5
+ user = User.find_by_id(3)
+ user.language = "zh-TW"
+ assert user.save
+ str_utf8 = "\xe4\xbb\xa5\xe5\x86\x85"
+ if str_utf8.respond_to?(:force_encoding)
+ str_utf8.force_encoding('UTF-8')
+ end
+ @request.session[:user_id] = 3
+ post :create, :project_id => 1,
+ :time_entry => {:comments => str_utf8,
+ # Not the default activity
+ :activity_id => '11',
+ :issue_id => '',
+ :spent_on => '2011-11-10',
+ :hours => '7.3'}
+ assert_redirected_to :action => 'index', :project_id => 'ecookbook'
+
+ t = TimeEntry.find_by_comments(str_utf8)
+ assert_not_nil t
+ assert_equal 11, t.activity_id
+ assert_equal 7.3, t.hours
+ assert_equal 3, t.user_id
+
+ get :index, :project_id => 1, :format => 'csv',
+ :from => '2011-11-10', :to => '2011-11-10'
+ assert_response :success
+ assert_equal 'text/csv', @response.content_type
+ ar = @response.body.chomp.split("\n")
+ s1 = "\xa4\xe9\xb4\xc1"
+ if str_utf8.respond_to?(:force_encoding)
+ s1.force_encoding('Big5')
+ end
+ assert ar[0].include?(s1)
+ s2 = ar[1].split(",")[8]
+ if s2.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