mirror of
https://github.com/fluent/fluentd-ui.git
synced 2025-08-12 09:17:05 +02:00
Merge pull request #135 from fluent/cosme_and_trivial_refactors
Cosme and trivial refactors
This commit is contained in:
commit
9d227a190d
@ -75,28 +75,38 @@ class ApplicationController < ActionController::Base
|
||||
end
|
||||
|
||||
def set_locale
|
||||
available = I18n.available_locales.map(&:to_s)
|
||||
if params[:lang] && available.include?(params[:lang])
|
||||
I18n.locale = locale_from_params || locale_from_session || locale_from_http_accept_lang || I18n.default_locale
|
||||
end
|
||||
|
||||
def locale_from_params
|
||||
if params[:lang] && available_locales.include?(params[:lang])
|
||||
session[:prefer_lang] = params[:lang]
|
||||
I18n.locale = params[:lang]
|
||||
return
|
||||
params[:lang]
|
||||
else
|
||||
nil
|
||||
end
|
||||
if session[:prefer_lang]
|
||||
I18n.locale = session[:prefer_lang]
|
||||
return
|
||||
end
|
||||
|
||||
def locale_from_session
|
||||
session[:prefer_lang]
|
||||
end
|
||||
|
||||
def locale_from_http_accept_lang
|
||||
# NOTE: ignoring q=xxx in request header for now
|
||||
return nil if request.env["HTTP_ACCEPT_LANGUAGE"].blank?
|
||||
|
||||
langs = request.env["HTTP_ACCEPT_LANGUAGE"].gsub(/q=[0-9.]+/, "").gsub(";","").split(",")
|
||||
prefer = langs.find { |lang| available_locales.include?(lang) }
|
||||
|
||||
unless prefer
|
||||
prefer = :en if langs.find{ |lang| lang.match(/^en/) }
|
||||
end
|
||||
|
||||
# NOTE: ignoring q=xxx in request header for now
|
||||
return if request.env["HTTP_ACCEPT_LANGUAGE"].blank?
|
||||
langs = request.env["HTTP_ACCEPT_LANGUAGE"].gsub(/q=[0-9.]+/, "").gsub(";","").split(",")
|
||||
prefer = langs.find {|lang| available.include?(lang) }
|
||||
unless prefer
|
||||
if langs.find{|lang| lang.match(/^en/)}
|
||||
I18n.locale = :en
|
||||
return
|
||||
end
|
||||
end
|
||||
I18n.locale = prefer
|
||||
prefer
|
||||
end
|
||||
|
||||
def available_locales
|
||||
@available_locales ||= I18n.available_locales.map(&:to_s)
|
||||
end
|
||||
|
||||
def file_tail(path, limit = 10)
|
||||
|
@ -1,2 +0,0 @@
|
||||
module MiscsHelper
|
||||
end
|
@ -1,7 +0,0 @@
|
||||
# This file should contain all the record creation needed to seed the database with its default values.
|
||||
# The data can then be loaded with the rake db:seed (or created alongside the db with db:setup).
|
||||
#
|
||||
# Examples:
|
||||
#
|
||||
# cities = City.create([{ name: 'Chicago' }, { name: 'Copenhagen' }])
|
||||
# Mayor.create(name: 'Emanuel', city: cities.first)
|
88
spec/controllers/application_controller_spec.rb
Normal file
88
spec/controllers/application_controller_spec.rb
Normal file
@ -0,0 +1,88 @@
|
||||
require 'spec_helper'
|
||||
|
||||
class DummyController < ApplicationController; end
|
||||
|
||||
describe DummyController do
|
||||
controller DummyController do
|
||||
skip_before_action :login_required
|
||||
def index
|
||||
render :text => "Hello World"
|
||||
end
|
||||
end
|
||||
|
||||
describe '#set_locale' do
|
||||
let!(:default_locale) { :en }
|
||||
let!(:available_locales) { [:en, :ja] }
|
||||
|
||||
before do
|
||||
I18n.stub(:default_locale).and_return(default_locale)
|
||||
I18n.stub(:available_locales).and_return(available_locales)
|
||||
|
||||
I18n.locale = I18n.default_locale #initialize
|
||||
end
|
||||
|
||||
context 'with params[:lang]' do
|
||||
before do
|
||||
get 'index', lang: param_lang
|
||||
end
|
||||
|
||||
context 'and in available_locales' do
|
||||
let(:param_lang) { :ja }
|
||||
|
||||
it 'params[:lang] will be set as locale' do
|
||||
expect(I18n.locale).to eq :ja
|
||||
end
|
||||
end
|
||||
|
||||
context 'and out of available_locales' do
|
||||
let(:param_lang) { :ka }
|
||||
|
||||
it 'defalut locale will be set as locale' do
|
||||
expect(I18n.locale).to eq default_locale
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context 'with session[:prefer_lang]' do
|
||||
before do
|
||||
controller.session[:prefer_lang] = :ja
|
||||
end
|
||||
|
||||
it 'session[:prefer_lang] will be set as locale' do
|
||||
get 'index'
|
||||
expect(I18n.locale).to eq :ja
|
||||
end
|
||||
end
|
||||
|
||||
context 'with request.env["HTTP_ACCEPT_LANGUAGE"]' do
|
||||
before do
|
||||
request.stub(:env).and_return({ "HTTP_ACCEPT_LANGUAGE" => accept_language })
|
||||
get 'index'
|
||||
end
|
||||
|
||||
context 'accept_language is available' do
|
||||
let(:accept_language) { 'ja' }
|
||||
|
||||
it 'session[:prefer_lang] will be set as locale' do
|
||||
expect(I18n.locale).to eq :ja
|
||||
end
|
||||
end
|
||||
|
||||
context 'accept_language is not available but start with en' do
|
||||
let(:accept_language) { 'en-us' }
|
||||
|
||||
it ':en will be set as locale' do
|
||||
expect(I18n.locale).to eq :en
|
||||
end
|
||||
end
|
||||
|
||||
context 'accept_language is not available' do
|
||||
let(:accept_language) { 'ka' }
|
||||
|
||||
it 'default_locale will be set as locale' do
|
||||
expect(I18n.locale).to eq default_locale
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue
Block a user