@@ -84,7 +84,6 module TimelogHelper | |||||
84 | end |
|
84 | end | |
85 |
|
85 | |||
86 | def entries_to_csv(entries) |
|
86 | def entries_to_csv(entries) | |
87 | ic = Iconv.new(l(:general_csv_encoding), 'UTF-8') |
|
|||
88 | decimal_separator = l(:general_csv_decimal_separator) |
|
87 | decimal_separator = l(:general_csv_decimal_separator) | |
89 | custom_fields = TimeEntryCustomField.find(:all) |
|
88 | custom_fields = TimeEntryCustomField.find(:all) | |
90 | export = FCSV.generate(:col_sep => l(:general_csv_separator)) do |csv| |
|
89 | export = FCSV.generate(:col_sep => l(:general_csv_separator)) do |csv| | |
@@ -102,7 +101,9 module TimelogHelper | |||||
102 | # Export custom fields |
|
101 | # Export custom fields | |
103 | headers += custom_fields.collect(&:name) |
|
102 | headers += custom_fields.collect(&:name) | |
104 |
|
103 | |||
105 | csv << headers.collect {|c| begin; ic.iconv(c.to_s); rescue; c.to_s; end } |
|
104 | csv << headers.collect {|c| Redmine::CodesetUtil.from_utf8( | |
|
105 | c.to_s, | |||
|
106 | l(:general_csv_encoding) ) } | |||
106 | # csv lines |
|
107 | # csv lines | |
107 | entries.each do |entry| |
|
108 | entries.each do |entry| | |
108 | fields = [format_date(entry.spent_on), |
|
109 | fields = [format_date(entry.spent_on), | |
@@ -117,7 +118,9 module TimelogHelper | |||||
117 | ] |
|
118 | ] | |
118 | fields += custom_fields.collect {|f| show_value(entry.custom_value_for(f)) } |
|
119 | fields += custom_fields.collect {|f| show_value(entry.custom_value_for(f)) } | |
119 |
|
120 | |||
120 | csv << fields.collect {|c| begin; ic.iconv(c.to_s); rescue; c.to_s; end } |
|
121 | csv << fields.collect {|c| Redmine::CodesetUtil.from_utf8( | |
|
122 | c.to_s, | |||
|
123 | l(:general_csv_encoding) ) } | |||
121 | end |
|
124 | end | |
122 | end |
|
125 | end | |
123 | export |
|
126 | export |
@@ -368,4 +368,50 class TimelogControllerTest < ActionController::TestCase | |||||
368 | assert ar[0].include?(s1) |
|
368 | assert ar[0].include?(s1) | |
369 | assert ar[1].include?(str_big5) |
|
369 | assert ar[1].include?(str_big5) | |
370 | end |
|
370 | end | |
|
371 | ||||
|
372 | def test_csv_cannot_convert_should_be_replaced_big_5 | |||
|
373 | user = User.find_by_id(3) | |||
|
374 | user.language = "zh-TW" | |||
|
375 | assert user.save | |||
|
376 | str_utf8 = "\xe4\xbb\xa5\xe5\x86\x85" | |||
|
377 | if str_utf8.respond_to?(:force_encoding) | |||
|
378 | str_utf8.force_encoding('UTF-8') | |||
|
379 | end | |||
|
380 | @request.session[:user_id] = 3 | |||
|
381 | post :create, :project_id => 1, | |||
|
382 | :time_entry => {:comments => str_utf8, | |||
|
383 | # Not the default activity | |||
|
384 | :activity_id => '11', | |||
|
385 | :issue_id => '', | |||
|
386 | :spent_on => '2011-11-10', | |||
|
387 | :hours => '7.3'} | |||
|
388 | assert_redirected_to :action => 'index', :project_id => 'ecookbook' | |||
|
389 | ||||
|
390 | t = TimeEntry.find_by_comments(str_utf8) | |||
|
391 | assert_not_nil t | |||
|
392 | assert_equal 11, t.activity_id | |||
|
393 | assert_equal 7.3, t.hours | |||
|
394 | assert_equal 3, t.user_id | |||
|
395 | ||||
|
396 | get :index, :project_id => 1, :format => 'csv', | |||
|
397 | :from => '2011-11-10', :to => '2011-11-10' | |||
|
398 | assert_response :success | |||
|
399 | assert_equal 'text/csv', @response.content_type | |||
|
400 | ar = @response.body.chomp.split("\n") | |||
|
401 | s1 = "\xa4\xe9\xb4\xc1" | |||
|
402 | if str_utf8.respond_to?(:force_encoding) | |||
|
403 | s1.force_encoding('Big5') | |||
|
404 | end | |||
|
405 | assert ar[0].include?(s1) | |||
|
406 | s2 = ar[1].split(",")[8] | |||
|
407 | if s2.respond_to?(:force_encoding) | |||
|
408 | s3 = "\xa5H?" | |||
|
409 | s3.force_encoding('Big5') | |||
|
410 | assert_equal s3, s2 | |||
|
411 | elsif RUBY_PLATFORM == 'java' | |||
|
412 | assert_equal "??", s2 | |||
|
413 | else | |||
|
414 | assert_equal "\xa5H???", s2 | |||
|
415 | end | |||
|
416 | end | |||
371 | end |
|
417 | end |
General Comments 0
You need to be logged in to leave comments.
Login now