]> source.dussan.org Git - redmine.git/commitdiff
Fixed a bug in localization introduced by r1131 (anonymous users inherit the language...
authorJean-Philippe Lang <jp_lang@yahoo.fr>
Wed, 13 Feb 2008 20:47:27 +0000 (20:47 +0000)
committerJean-Philippe Lang <jp_lang@yahoo.fr>
Wed, 13 Feb 2008 20:47:27 +0000 (20:47 +0000)
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1144 e93f8b46-1217-0410-a6f0-8f06a7374b81

app/controllers/application.rb
test/integration/application_test.rb [new file with mode: 0644]

index a6d881ff3ea90a683af783c341bb6423d8f29704..3644c396a52bdabb7b2dc621635212edcb659bce 100644 (file)
@@ -59,6 +59,7 @@ class ApplicationController < ActionController::Base
   end 
   
   def set_localization
+    User.current.language = nil unless User.current.logged?
     lang = begin
       if !User.current.language.blank? and GLoc.valid_languages.include? User.current.language.to_sym
         User.current.language
diff --git a/test/integration/application_test.rb b/test/integration/application_test.rb
new file mode 100644 (file)
index 0000000..18f4891
--- /dev/null
@@ -0,0 +1,43 @@
+# redMine - project management software
+# Copyright (C) 2006-2008  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"
+
+class ApplicationTest < ActionController::IntegrationTest
+  fixtures :users
+  
+  def test_set_localization
+    Setting.default_language = 'en'
+    
+    # a french user
+    get 'projects', { }, 'Accept-Language' => 'fr,fr-fr;q=0.8,en-us;q=0.5,en;q=0.3'
+    assert_response :success
+    assert_tag :tag => 'h2', :content => 'Projets'
+    assert_equal 'fr', User.current.language
+    
+    # then an italien user
+    get 'projects', { }, 'Accept-Language' => 'it;q=0.8,en-us;q=0.5,en;q=0.3'
+    assert_response :success
+    assert_tag :tag => 'h2', :content => 'Progetti'
+    assert_equal 'it', User.current.language
+    
+    # not a supported language: default language should be used
+    get 'projects', { }, 'Accept-Language' => 'zz'
+    assert_response :success
+    assert_tag :tag => 'h2', :content => 'Projects'
+  end
+end