require 'spec_helper' describe ProblemsHelper do describe '#truncated_problem_message' do it 'is html safe' do problem = double('problem', :message => '#') truncated = helper.truncated_problem_message(problem) expect(truncated).to be_html_safe expect(truncated).to_not include('<', '>') end end describe "#gravatar_tag" do let(:email) { "gravatar@example.com" } let(:email_hash) { Digest::MD5.hexdigest email } let(:base_url) { "http://www.gravatar.com/avatar/#{email_hash}" } context "default config" do before do Errbit::Config.stub(:use_gravatar).and_return(true) Errbit::Config.stub(:gravatar_default).and_return('identicon') end it "should render image_tag with correct alt and src" do expected = "\"#{email}\"" expect(helper.gravatar_tag(email, :s => 48)).to eq(expected) end it "should override :d" do expected = "\"#{email}\"" expect(helper.gravatar_tag(email, :d => 'retro', :s => 48)).to eq(expected) end end context "no email" do it "should not render the tag" do expect(helper.gravatar_tag(nil)).to be_nil end end end describe "#gravatar_url" do context "no email" do let(:email) { nil } it "should return nil" do expect(helper.gravatar_url(email)).to be_nil end end context "without ssl" do let(:email) { "gravatar@example.com" } let(:email_hash) { Digest::MD5.hexdigest email } it "should return the http url" do expect(helper.gravatar_url(email)).to eq("http://www.gravatar.com/avatar/#{email_hash}?d=identicon") end end context "with ssl" do let(:email) { "gravatar@example.com" } let(:email_hash) { Digest::MD5.hexdigest email } it "should return the http url" do ActionController::TestRequest.any_instance.stub :ssl? => true expect(helper.gravatar_url(email)).to eq("https://secure.gravatar.com/avatar/#{email_hash}?d=identicon") end end end end