Mercurial > hg > soundsoftware-site
diff test/unit/lib/redmine/i18n_test.rb @ 524:1248a47e81b3 feature_36
Merge from branch "luisf"
author | luisf <luis.figueira@eecs.qmul.ac.uk> |
---|---|
date | Mon, 25 Jul 2011 14:39:38 +0100 |
parents | 753f1380d6bc |
children | bb32da3bea34 |
line wrap: on
line diff
--- a/test/unit/lib/redmine/i18n_test.rb Fri Jul 15 17:21:05 2011 +0100 +++ b/test/unit/lib/redmine/i18n_test.rb Mon Jul 25 14:39:38 2011 +0100 @@ -1,44 +1,44 @@ # Redmine - project management software -# Copyright (C) 2006-2009 Jean-Philippe Lang +# Copyright (C) 2006-2011 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' +require File.expand_path('../../../../test_helper', __FILE__) class Redmine::I18nTest < ActiveSupport::TestCase include Redmine::I18n include ActionView::Helpers::NumberHelper - + def setup @hook_module = Redmine::Hook end - + def test_date_format_default set_language_if_valid 'en' today = Date.today - Setting.date_format = '' - assert_equal I18n.l(today, :count => today.strftime('%d')), format_date(today) + Setting.date_format = '' + assert_equal I18n.l(today), format_date(today) end - + def test_date_format set_language_if_valid 'en' today = Date.today Setting.date_format = '%d %m %Y' assert_equal today.strftime('%d %m %Y'), format_date(today) end - + def test_date_and_time_for_each_language Setting.date_format = '' valid_languages.each do |lang| @@ -47,26 +47,49 @@ format_date(Date.today) format_time(Time.now) format_time(Time.now, false) - assert_not_equal 'default', ::I18n.l(Date.today, :count => Date.today.strftime('%d'), :format => :default), "date.formats.default missing in #{lang}" - assert_not_equal 'time', ::I18n.l(Time.now, :format => :time), "time.formats.time missing in #{lang}" + assert_not_equal 'default', ::I18n.l(Date.today, :format => :default), + "date.formats.default missing in #{lang}" + assert_not_equal 'time', ::I18n.l(Time.now, :format => :time), + "time.formats.time missing in #{lang}" end assert l('date.day_names').is_a?(Array) assert_equal 7, l('date.day_names').size - + assert l('date.month_names').is_a?(Array) assert_equal 13, l('date.month_names').size end end - + + def test_time_format + set_language_if_valid 'en' + now = Time.parse('2011-02-20 15:45:22') + with_settings :time_format => '%H:%M' do + with_settings :date_format => '' do + assert_equal '02/20/2011 15:45', format_time(now) + assert_equal '15:45', format_time(now, false) + end + with_settings :date_format => '%Y-%m-%d' do + assert_equal '2011-02-20 15:45', format_time(now) + assert_equal '15:45', format_time(now, false) + end + end + end + def test_time_format_default set_language_if_valid 'en' - now = Time.now - Setting.date_format = '' - Setting.time_format = '' - assert_equal I18n.l(now, :count => now.strftime('%d')), format_time(now) - assert_equal I18n.l(now, :count => now.strftime('%d'), :format => :time), format_time(now, false) + now = Time.parse('2011-02-20 15:45:22') + with_settings :time_format => '' do + with_settings :date_format => '' do + assert_equal '02/20/2011 03:45 pm', format_time(now) + assert_equal '03:45 pm', format_time(now, false) + end + with_settings :date_format => '%Y-%m-%d' do + assert_equal '2011-02-20 03:45 pm', format_time(now) + assert_equal '03:45 pm', format_time(now, false) + end + end end - + def test_time_format set_language_if_valid 'en' now = Time.now @@ -75,16 +98,16 @@ assert_equal now.strftime('%d %m %Y %H %M'), format_time(now) assert_equal now.strftime('%H %M'), format_time(now, false) end - + def test_utc_time_format set_language_if_valid 'en' - now = Time.now.utc + now = Time.now Setting.date_format = '%d %m %Y' Setting.time_format = '%H %M' - assert_equal Time.now.strftime('%d %m %Y %H %M'), format_time(now) - assert_equal Time.now.strftime('%H %M'), format_time(now, false) + assert_equal now.strftime('%d %m %Y %H %M'), format_time(now.utc) + assert_equal now.strftime('%H %M'), format_time(now.utc, false) end - + def test_number_to_human_size_for_each_language valid_languages.each do |lang| set_language_if_valid lang @@ -93,12 +116,12 @@ end end end - + def test_valid_languages assert valid_languages.is_a?(Array) assert valid_languages.first.is_a?(Symbol) end - + def test_valid_language to_test = {'fr' => :fr, 'Fr' => :fr, @@ -106,7 +129,31 @@ 'zh-tw' => :"zh-TW", 'zh-TW' => :"zh-TW", 'zh-ZZ' => nil } - to_test.each {|lang, expected| assert_equal expected, find_language(lang)} end + + def test_fallback + ::I18n.backend.store_translations(:en, {:untranslated => "Untranslated string"}) + ::I18n.locale = 'en' + assert_equal "Untranslated string", l(:untranslated) + ::I18n.locale = 'fr' + assert_equal "Untranslated string", l(:untranslated) + + ::I18n.backend.store_translations(:fr, {:untranslated => "Pas de traduction"}) + ::I18n.locale = 'en' + assert_equal "Untranslated string", l(:untranslated) + ::I18n.locale = 'fr' + assert_equal "Pas de traduction", l(:untranslated) + end + + def test_utf8 + set_language_if_valid 'ja' + str_ja_yes = "\xe3\x81\xaf\xe3\x81\x84" + i18n_ja_yes = l(:general_text_Yes) + if str_ja_yes.respond_to?(:force_encoding) + str_ja_yes.force_encoding('UTF-8') + assert_equal "UTF-8", i18n_ja_yes.encoding.to_s + end + assert_equal str_ja_yes, i18n_ja_yes + end end