Mercurial > hg > soundsoftware-site
comparison 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 |
comparison
equal
deleted
inserted
replaced
519:3be6bc3c2a17 | 524:1248a47e81b3 |
---|---|
1 # Redmine - project management software | 1 # Redmine - project management software |
2 # Copyright (C) 2006-2009 Jean-Philippe Lang | 2 # Copyright (C) 2006-2011 Jean-Philippe Lang |
3 # | 3 # |
4 # This program is free software; you can redistribute it and/or | 4 # This program is free software; you can redistribute it and/or |
5 # modify it under the terms of the GNU General Public License | 5 # modify it under the terms of the GNU General Public License |
6 # as published by the Free Software Foundation; either version 2 | 6 # as published by the Free Software Foundation; either version 2 |
7 # of the License, or (at your option) any later version. | 7 # of the License, or (at your option) any later version. |
8 # | 8 # |
9 # This program is distributed in the hope that it will be useful, | 9 # This program is distributed in the hope that it will be useful, |
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of |
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
12 # GNU General Public License for more details. | 12 # GNU General Public License for more details. |
13 # | 13 # |
14 # You should have received a copy of the GNU General Public License | 14 # You should have received a copy of the GNU General Public License |
15 # along with this program; if not, write to the Free Software | 15 # along with this program; if not, write to the Free Software |
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
17 | 17 |
18 require File.dirname(__FILE__) + '/../../../test_helper' | 18 require File.expand_path('../../../../test_helper', __FILE__) |
19 | 19 |
20 class Redmine::I18nTest < ActiveSupport::TestCase | 20 class Redmine::I18nTest < ActiveSupport::TestCase |
21 include Redmine::I18n | 21 include Redmine::I18n |
22 include ActionView::Helpers::NumberHelper | 22 include ActionView::Helpers::NumberHelper |
23 | 23 |
24 def setup | 24 def setup |
25 @hook_module = Redmine::Hook | 25 @hook_module = Redmine::Hook |
26 end | 26 end |
27 | 27 |
28 def test_date_format_default | 28 def test_date_format_default |
29 set_language_if_valid 'en' | 29 set_language_if_valid 'en' |
30 today = Date.today | 30 today = Date.today |
31 Setting.date_format = '' | 31 Setting.date_format = '' |
32 assert_equal I18n.l(today, :count => today.strftime('%d')), format_date(today) | 32 assert_equal I18n.l(today), format_date(today) |
33 end | 33 end |
34 | 34 |
35 def test_date_format | 35 def test_date_format |
36 set_language_if_valid 'en' | 36 set_language_if_valid 'en' |
37 today = Date.today | 37 today = Date.today |
38 Setting.date_format = '%d %m %Y' | 38 Setting.date_format = '%d %m %Y' |
39 assert_equal today.strftime('%d %m %Y'), format_date(today) | 39 assert_equal today.strftime('%d %m %Y'), format_date(today) |
40 end | 40 end |
41 | 41 |
42 def test_date_and_time_for_each_language | 42 def test_date_and_time_for_each_language |
43 Setting.date_format = '' | 43 Setting.date_format = '' |
44 valid_languages.each do |lang| | 44 valid_languages.each do |lang| |
45 set_language_if_valid lang | 45 set_language_if_valid lang |
46 assert_nothing_raised "#{lang} failure" do | 46 assert_nothing_raised "#{lang} failure" do |
47 format_date(Date.today) | 47 format_date(Date.today) |
48 format_time(Time.now) | 48 format_time(Time.now) |
49 format_time(Time.now, false) | 49 format_time(Time.now, false) |
50 assert_not_equal 'default', ::I18n.l(Date.today, :count => Date.today.strftime('%d'), :format => :default), "date.formats.default missing in #{lang}" | 50 assert_not_equal 'default', ::I18n.l(Date.today, :format => :default), |
51 assert_not_equal 'time', ::I18n.l(Time.now, :format => :time), "time.formats.time missing in #{lang}" | 51 "date.formats.default missing in #{lang}" |
52 assert_not_equal 'time', ::I18n.l(Time.now, :format => :time), | |
53 "time.formats.time missing in #{lang}" | |
52 end | 54 end |
53 assert l('date.day_names').is_a?(Array) | 55 assert l('date.day_names').is_a?(Array) |
54 assert_equal 7, l('date.day_names').size | 56 assert_equal 7, l('date.day_names').size |
55 | 57 |
56 assert l('date.month_names').is_a?(Array) | 58 assert l('date.month_names').is_a?(Array) |
57 assert_equal 13, l('date.month_names').size | 59 assert_equal 13, l('date.month_names').size |
58 end | 60 end |
59 end | 61 end |
60 | 62 |
63 def test_time_format | |
64 set_language_if_valid 'en' | |
65 now = Time.parse('2011-02-20 15:45:22') | |
66 with_settings :time_format => '%H:%M' do | |
67 with_settings :date_format => '' do | |
68 assert_equal '02/20/2011 15:45', format_time(now) | |
69 assert_equal '15:45', format_time(now, false) | |
70 end | |
71 with_settings :date_format => '%Y-%m-%d' do | |
72 assert_equal '2011-02-20 15:45', format_time(now) | |
73 assert_equal '15:45', format_time(now, false) | |
74 end | |
75 end | |
76 end | |
77 | |
61 def test_time_format_default | 78 def test_time_format_default |
62 set_language_if_valid 'en' | 79 set_language_if_valid 'en' |
63 now = Time.now | 80 now = Time.parse('2011-02-20 15:45:22') |
64 Setting.date_format = '' | 81 with_settings :time_format => '' do |
65 Setting.time_format = '' | 82 with_settings :date_format => '' do |
66 assert_equal I18n.l(now, :count => now.strftime('%d')), format_time(now) | 83 assert_equal '02/20/2011 03:45 pm', format_time(now) |
67 assert_equal I18n.l(now, :count => now.strftime('%d'), :format => :time), format_time(now, false) | 84 assert_equal '03:45 pm', format_time(now, false) |
85 end | |
86 with_settings :date_format => '%Y-%m-%d' do | |
87 assert_equal '2011-02-20 03:45 pm', format_time(now) | |
88 assert_equal '03:45 pm', format_time(now, false) | |
89 end | |
90 end | |
68 end | 91 end |
69 | 92 |
70 def test_time_format | 93 def test_time_format |
71 set_language_if_valid 'en' | 94 set_language_if_valid 'en' |
72 now = Time.now | 95 now = Time.now |
73 Setting.date_format = '%d %m %Y' | 96 Setting.date_format = '%d %m %Y' |
74 Setting.time_format = '%H %M' | 97 Setting.time_format = '%H %M' |
75 assert_equal now.strftime('%d %m %Y %H %M'), format_time(now) | 98 assert_equal now.strftime('%d %m %Y %H %M'), format_time(now) |
76 assert_equal now.strftime('%H %M'), format_time(now, false) | 99 assert_equal now.strftime('%H %M'), format_time(now, false) |
77 end | 100 end |
78 | 101 |
79 def test_utc_time_format | 102 def test_utc_time_format |
80 set_language_if_valid 'en' | 103 set_language_if_valid 'en' |
81 now = Time.now.utc | 104 now = Time.now |
82 Setting.date_format = '%d %m %Y' | 105 Setting.date_format = '%d %m %Y' |
83 Setting.time_format = '%H %M' | 106 Setting.time_format = '%H %M' |
84 assert_equal Time.now.strftime('%d %m %Y %H %M'), format_time(now) | 107 assert_equal now.strftime('%d %m %Y %H %M'), format_time(now.utc) |
85 assert_equal Time.now.strftime('%H %M'), format_time(now, false) | 108 assert_equal now.strftime('%H %M'), format_time(now.utc, false) |
86 end | 109 end |
87 | 110 |
88 def test_number_to_human_size_for_each_language | 111 def test_number_to_human_size_for_each_language |
89 valid_languages.each do |lang| | 112 valid_languages.each do |lang| |
90 set_language_if_valid lang | 113 set_language_if_valid lang |
91 assert_nothing_raised "#{lang} failure" do | 114 assert_nothing_raised "#{lang} failure" do |
92 number_to_human_size(1024*1024*4) | 115 number_to_human_size(1024*1024*4) |
93 end | 116 end |
94 end | 117 end |
95 end | 118 end |
96 | 119 |
97 def test_valid_languages | 120 def test_valid_languages |
98 assert valid_languages.is_a?(Array) | 121 assert valid_languages.is_a?(Array) |
99 assert valid_languages.first.is_a?(Symbol) | 122 assert valid_languages.first.is_a?(Symbol) |
100 end | 123 end |
101 | 124 |
102 def test_valid_language | 125 def test_valid_language |
103 to_test = {'fr' => :fr, | 126 to_test = {'fr' => :fr, |
104 'Fr' => :fr, | 127 'Fr' => :fr, |
105 'zh' => :zh, | 128 'zh' => :zh, |
106 'zh-tw' => :"zh-TW", | 129 'zh-tw' => :"zh-TW", |
107 'zh-TW' => :"zh-TW", | 130 'zh-TW' => :"zh-TW", |
108 'zh-ZZ' => nil } | 131 'zh-ZZ' => nil } |
109 | |
110 to_test.each {|lang, expected| assert_equal expected, find_language(lang)} | 132 to_test.each {|lang, expected| assert_equal expected, find_language(lang)} |
111 end | 133 end |
134 | |
135 def test_fallback | |
136 ::I18n.backend.store_translations(:en, {:untranslated => "Untranslated string"}) | |
137 ::I18n.locale = 'en' | |
138 assert_equal "Untranslated string", l(:untranslated) | |
139 ::I18n.locale = 'fr' | |
140 assert_equal "Untranslated string", l(:untranslated) | |
141 | |
142 ::I18n.backend.store_translations(:fr, {:untranslated => "Pas de traduction"}) | |
143 ::I18n.locale = 'en' | |
144 assert_equal "Untranslated string", l(:untranslated) | |
145 ::I18n.locale = 'fr' | |
146 assert_equal "Pas de traduction", l(:untranslated) | |
147 end | |
148 | |
149 def test_utf8 | |
150 set_language_if_valid 'ja' | |
151 str_ja_yes = "\xe3\x81\xaf\xe3\x81\x84" | |
152 i18n_ja_yes = l(:general_text_Yes) | |
153 if str_ja_yes.respond_to?(:force_encoding) | |
154 str_ja_yes.force_encoding('UTF-8') | |
155 assert_equal "UTF-8", i18n_ja_yes.encoding.to_s | |
156 end | |
157 assert_equal str_ja_yes, i18n_ja_yes | |
158 end | |
112 end | 159 end |