Commit 336750c9 authored by Christian Höltje's avatar Christian Höltje

user_color_scheme_class with current_user

This refactors the `user_color_scheme_class` to use
a hash with a default.  This prevents problems
with workers that don't have access to the
current_user.

Fixes issue #2758
parent 0447c731
......@@ -2,6 +2,13 @@ require 'digest/md5'
require 'uri'
module ApplicationHelper
COLOR_SCHEMES = {
1 => 'white',
2 => 'black',
3 => 'solarized-dark',
4 => 'monokai',
}
COLOR_SCHEMES.default = 'white'
# Check if a particular controller is the current one
#
......@@ -124,17 +131,7 @@ module ApplicationHelper
end
def user_color_scheme_class
# in case we dont have current_user (ex. in mailer)
return 1 unless defined?(current_user)
case current_user.color_scheme_id
when 1 then 'white'
when 2 then 'black'
when 3 then 'solarized-dark'
when 4 then 'monokai'
else
'white'
end
COLOR_SCHEMES[current_user.try(:color_scheme_id)]
end
# Define whenever show last push event
......
......@@ -83,4 +83,26 @@ describe ApplicationHelper do
end
end
describe "user_color_scheme_class" do
context "with current_user is nil" do
it "should return a string" do
stub!(:current_user).and_return(nil)
user_color_scheme_class.should be_kind_of(String)
end
end
context "with a current_user" do
(1..5).each do |color_scheme_id|
context "with color_scheme_id == #{color_scheme_id}" do
it "should return a string" do
current_user = double(:color_scheme_id => color_scheme_id)
stub!(:current_user).and_return(current_user)
user_color_scheme_class.should be_kind_of(String)
end
end
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment