Fixed a bug in localization introduced by r1131 (anonymous users inherit the language of the first anonymous user).

git-svn-id: http://redmine.rubyforge.org/svn/trunk@1144 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2008-02-13 20:47:27 +00:00
parent 0b6a010a12
commit 8adb320978
2 changed files with 44 additions and 0 deletions

View File

@ -59,6 +59,7 @@ class ApplicationController < ActionController::Base
end end
def set_localization def set_localization
User.current.language = nil unless User.current.logged?
lang = begin lang = begin
if !User.current.language.blank? and GLoc.valid_languages.include? User.current.language.to_sym if !User.current.language.blank? and GLoc.valid_languages.include? User.current.language.to_sym
User.current.language User.current.language

View File

@ -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