summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2018-01-07 22:01:56 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2018-01-07 22:01:56 +0000
commitc7948ed40d9e74b3ee1d9f674913aaad04ab5f85 (patch)
tree1508148992556634f621615c810a579a835b181a
parent4e6b54e33e67d795ffdb90f74c7a526dc34b9301 (diff)
downloadredmine-c7948ed40d9e74b3ee1d9f674913aaad04ab5f85.tar.gz
redmine-c7948ed40d9e74b3ee1d9f674913aaad04ab5f85.zip
Anonymous user should have their icon (#26699).
Patch by Go MAEDA. git-svn-id: http://svn.redmine.org/redmine/trunk@17150 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/helpers/application_helper.rb8
-rw-r--r--public/images/anonymous.pngbin0 -> 1072 bytes
-rw-r--r--test/helpers/application_helper_test.rb7
3 files changed, 12 insertions, 3 deletions
diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
index ef229f955..a70add6f8 100644
--- a/app/helpers/application_helper.rb
+++ b/app/helpers/application_helper.rb
@@ -1405,7 +1405,13 @@ module ApplicationHelper
elsif user.to_s =~ %r{<(.+?)>}
email = $1
end
- return gravatar(email.to_s.downcase, options) unless email.blank? rescue nil
+ if email.present?
+ gravatar(email.to_s.downcase, options) rescue nil
+ else
+ image_tag 'anonymous.png',
+ GravatarHelper::DEFAULT_OPTIONS
+ .except(:default, :rating, :ssl).merge(options)
+ end
else
''
end
diff --git a/public/images/anonymous.png b/public/images/anonymous.png
new file mode 100644
index 000000000..5f00a8362
--- /dev/null
+++ b/public/images/anonymous.png
Binary files differ
diff --git a/test/helpers/application_helper_test.rb b/test/helpers/application_helper_test.rb
index 6a461c31a..936a0ba84 100644
--- a/test/helpers/application_helper_test.rb
+++ b/test/helpers/application_helper_test.rb
@@ -1302,6 +1302,7 @@ RAW
end
def test_avatar_enabled
+ tag_for_anonymous_re = %r{src="/images/anonymous.png(\?\d+)?"}
with_settings :gravatar_enabled => '1' do
assert avatar(User.find_by_mail('jsmith@somenet.foo')).include?(Digest::MD5.hexdigest('jsmith@somenet.foo'))
assert avatar('jsmith <jsmith@somenet.foo>').include?(Digest::MD5.hexdigest('jsmith@somenet.foo'))
@@ -1313,8 +1314,10 @@ RAW
# The default class of the img tag should be gravatar
assert avatar('jsmith <jsmith@somenet.foo>').include?('class="gravatar"')
assert !avatar('jsmith <jsmith@somenet.foo>', :class => 'picture').include?('class="gravatar"')
- assert_nil avatar('jsmith')
- assert_nil avatar(nil)
+ assert_match tag_for_anonymous_re, avatar('jsmith')
+ assert_match tag_for_anonymous_re, avatar(nil)
+ # Avatar for anonymous user
+ assert_match tag_for_anonymous_re, avatar(User.anonymous)
end
end