Mercurial > hg > soundsoftware-site
comparison test/unit/lib/redmine/.svn/text-base/i18n_test.rb.svn-base @ 441:cbce1fd3b1b7 redmine-1.2
Update to Redmine 1.2-stable branch (Redmine SVN rev 6000)
author | Chris Cannam |
---|---|
date | Mon, 06 Jun 2011 14:24:13 +0100 |
parents | 051f544170fe |
children | 753f1380d6bc |
comparison
equal
deleted
inserted
replaced
245:051f544170fe | 441:cbce1fd3b1b7 |
---|---|
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.expand_path('../../../../test_helper', __FILE__) | 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), 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, :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 |
61 def test_time_format | 63 def test_time_format |
62 set_language_if_valid 'en' | 64 set_language_if_valid 'en' |
63 now = Time.parse('2011-02-20 15:45:22') | 65 now = Time.parse('2011-02-20 15:45:22') |
64 with_settings :time_format => '%H:%M' do | 66 with_settings :time_format => '%H:%M' do |
65 with_settings :date_format => '' do | 67 with_settings :date_format => '' do |
66 assert_equal '02/20/2011 15:45', format_time(now) | 68 assert_equal '02/20/2011 15:45', format_time(now) |
67 assert_equal '15:45', format_time(now, false) | 69 assert_equal '15:45', format_time(now, false) |
68 end | 70 end |
69 | |
70 with_settings :date_format => '%Y-%m-%d' do | 71 with_settings :date_format => '%Y-%m-%d' do |
71 assert_equal '2011-02-20 15:45', format_time(now) | 72 assert_equal '2011-02-20 15:45', format_time(now) |
72 assert_equal '15:45', format_time(now, false) | 73 assert_equal '15:45', format_time(now, false) |
73 end | 74 end |
74 end | 75 end |
75 end | 76 end |
76 | 77 |
77 def test_time_format_default | 78 def test_time_format_default |
78 set_language_if_valid 'en' | 79 set_language_if_valid 'en' |
79 now = Time.parse('2011-02-20 15:45:22') | 80 now = Time.parse('2011-02-20 15:45:22') |
80 with_settings :time_format => '' do | 81 with_settings :time_format => '' do |
81 with_settings :date_format => '' do | 82 with_settings :date_format => '' do |
82 assert_equal '02/20/2011 03:45 pm', format_time(now) | 83 assert_equal '02/20/2011 03:45 pm', format_time(now) |
83 assert_equal '03:45 pm', format_time(now, false) | 84 assert_equal '03:45 pm', format_time(now, false) |
84 end | 85 end |
85 | |
86 with_settings :date_format => '%Y-%m-%d' do | 86 with_settings :date_format => '%Y-%m-%d' do |
87 assert_equal '2011-02-20 03:45 pm', format_time(now) | 87 assert_equal '2011-02-20 03:45 pm', format_time(now) |
88 assert_equal '03:45 pm', format_time(now, false) | 88 assert_equal '03:45 pm', format_time(now, false) |
89 end | 89 end |
90 end | 90 end |
91 end | 91 end |
92 | 92 |
93 def test_time_format | 93 def test_time_format |
94 set_language_if_valid 'en' | 94 set_language_if_valid 'en' |
95 now = Time.now | 95 now = Time.now |
96 Setting.date_format = '%d %m %Y' | 96 Setting.date_format = '%d %m %Y' |
97 Setting.time_format = '%H %M' | 97 Setting.time_format = '%H %M' |
98 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) |
99 assert_equal now.strftime('%H %M'), format_time(now, false) | 99 assert_equal now.strftime('%H %M'), format_time(now, false) |
100 end | 100 end |
101 | 101 |
102 def test_utc_time_format | 102 def test_utc_time_format |
103 set_language_if_valid 'en' | 103 set_language_if_valid 'en' |
104 now = Time.now.utc | 104 now = Time.now |
105 Setting.date_format = '%d %m %Y' | 105 Setting.date_format = '%d %m %Y' |
106 Setting.time_format = '%H %M' | 106 Setting.time_format = '%H %M' |
107 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) |
108 assert_equal Time.now.strftime('%H %M'), format_time(now, false) | 108 assert_equal now.strftime('%H %M'), format_time(now.utc, false) |
109 end | 109 end |
110 | 110 |
111 def test_number_to_human_size_for_each_language | 111 def test_number_to_human_size_for_each_language |
112 valid_languages.each do |lang| | 112 valid_languages.each do |lang| |
113 set_language_if_valid lang | 113 set_language_if_valid lang |
114 assert_nothing_raised "#{lang} failure" do | 114 assert_nothing_raised "#{lang} failure" do |
115 number_to_human_size(1024*1024*4) | 115 number_to_human_size(1024*1024*4) |
116 end | 116 end |
117 end | 117 end |
118 end | 118 end |
119 | 119 |
120 def test_valid_languages | 120 def test_valid_languages |
121 assert valid_languages.is_a?(Array) | 121 assert valid_languages.is_a?(Array) |
122 assert valid_languages.first.is_a?(Symbol) | 122 assert valid_languages.first.is_a?(Symbol) |
123 end | 123 end |
124 | 124 |
125 def test_valid_language | 125 def test_valid_language |
126 to_test = {'fr' => :fr, | 126 to_test = {'fr' => :fr, |
127 'Fr' => :fr, | 127 'Fr' => :fr, |
128 'zh' => :zh, | 128 'zh' => :zh, |
129 'zh-tw' => :"zh-TW", | 129 'zh-tw' => :"zh-TW", |
130 'zh-TW' => :"zh-TW", | 130 'zh-TW' => :"zh-TW", |
131 'zh-ZZ' => nil } | 131 'zh-ZZ' => nil } |
132 | |
133 to_test.each {|lang, expected| assert_equal expected, find_language(lang)} | 132 to_test.each {|lang, expected| assert_equal expected, find_language(lang)} |
134 end | 133 end |
135 | 134 |
136 def test_fallback | 135 def test_fallback |
137 ::I18n.backend.store_translations(:en, {:untranslated => "Untranslated string"}) | 136 ::I18n.backend.store_translations(:en, {:untranslated => "Untranslated string"}) |
138 ::I18n.locale = 'en' | 137 ::I18n.locale = 'en' |
139 assert_equal "Untranslated string", l(:untranslated) | 138 assert_equal "Untranslated string", l(:untranslated) |
140 ::I18n.locale = 'fr' | 139 ::I18n.locale = 'fr' |
141 assert_equal "Untranslated string", l(:untranslated) | 140 assert_equal "Untranslated string", l(:untranslated) |
142 | 141 |
143 ::I18n.backend.store_translations(:fr, {:untranslated => "Pas de traduction"}) | 142 ::I18n.backend.store_translations(:fr, {:untranslated => "Pas de traduction"}) |
144 ::I18n.locale = 'en' | 143 ::I18n.locale = 'en' |
145 assert_equal "Untranslated string", l(:untranslated) | 144 assert_equal "Untranslated string", l(:untranslated) |
146 ::I18n.locale = 'fr' | 145 ::I18n.locale = 'fr' |
147 assert_equal "Pas de traduction", l(:untranslated) | 146 assert_equal "Pas de traduction", l(:untranslated) |
148 end | 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 | |
149 end | 159 end |