Sha256: 92fb9044ca9d0c1ce3eaeca725efa628672eb511864b480c1a882a0eecb2d787

Contents?: true

Size: 1.66 KB

Versions: 8

Compression:

Stored size: 1.66 KB

Contents

require 'spec_helper'

describe HomeController do
  let(:logger_mock) { double("Rails.logger").as_null_object }

  before(:each) do
    reset_configuration
    Rollbar.configure do |config|
      config.access_token = 'aaaabbbbccccddddeeeeffff00001111'
      config.environment = ::Rails.env
      config.root = ::Rails.root
      config.framework = "Rails: #{::Rails::VERSION::STRING}"
      config.logger = logger_mock
    end
  end

  context "with broken request" do
    it "should report uncaught exceptions" do
      expect{ get 'current_user', nil, :cookie => '8%B' }.to raise_exception

      Rollbar.last_report.should_not be_nil

      exception_info = Rollbar.last_report[:body][:trace][:exception]
      exception_info[:class].should == 'ArgumentError'
      exception_info[:message].should == 'invalid %-encoding (8%B)'
    end
  end

  context "with error hiding deep inside" do
    let!(:cookie_method_name){ :[] }
    let!(:original_cookie_method){ ActionDispatch::Cookies::CookieJar.instance_method(cookie_method_name) }
    let!(:broken_cookie_method){ Proc.new{ |name| "1" - 1 } }

    before(:each) do
      ActionDispatch::Cookies::CookieJar.send(:define_method, cookie_method_name, broken_cookie_method)
    end

    after(:each) do
      ActionDispatch::Cookies::CookieJar.send(:define_method, cookie_method_name, original_cookie_method)
    end

    it "should report uncaught exceptions" do
      expect{ get 'current_user' }.to raise_exception

      exception_info = Rollbar.last_report[:body][:trace][:exception]
      exception_info[:class].should == 'NoMethodError'
      # exception_info[:message].should == 'undefined method `-\' for "1":String'
    end
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
rollbar-0.10.2 spec/requests/home_spec.rb
rollbar-0.10.1 spec/requests/home_spec.rb
rollbar-0.10.0 spec/requests/home_spec.rb
rollbar-0.9.14 spec/requests/home_spec.rb
rollbar-0.9.13 spec/requests/home_spec.rb
rollbar-0.9.12 spec/requests/home_spec.rb
rollbar-0.9.11 spec/requests/home_spec.rb
rollbar-0.9.10 spec/requests/home_spec.rb