Skip to content

Commit

Permalink
airbrake-ruby: fix add_filter block API
Browse files Browse the repository at this point in the history
Fixes #8 (add_filter throwing exception)
  • Loading branch information
kyrylo committed Dec 22, 2015
1 parent 3afa58a commit 5696a0c
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 3 deletions.
4 changes: 2 additions & 2 deletions lib/airbrake-ruby.rb
Original file line number Diff line number Diff line change
Expand Up @@ -275,9 +275,9 @@ def create_deploy(deploy_params, notifier = :default)
# Calls +method+ on +notifier+ with provided +args+.
#
# @raise [Airbrake::Error] if none of the notifiers exist
def call_notifier(notifier, method, *args)
def call_notifier(notifier, method, *args, &block)
if @notifiers.key?(notifier)
@notifiers[notifier].__send__(method, *args)
@notifiers[notifier].__send__(method, *args, &block)
else
raise Airbrake::Error,
"the '#{notifier}' notifier isn't configured"
Expand Down
14 changes: 13 additions & 1 deletion spec/airbrake_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
end

before do
described_class.configure do |c|
@notifier = described_class.configure do |c|
c.project_id = 113743
c.project_key = 'fd04e13d806a90f96614ad8e529b2822'
end
Expand Down Expand Up @@ -161,6 +161,18 @@

describe ".add_filter" do
include_examples 'error handling', :add_filter

it "adds filters with help of blocks" do
filter_chain = @notifier.instance_variable_get(:@filter_chain)
filters = filter_chain.instance_variable_get(:@filters)

expect(filters.size).to eq(2)

described_class.add_filter {}

expect(filters.size).to eq(3)
expect(filters.last).to be_a(Proc)
end
end

describe ".whitelist_keys" do
Expand Down

0 comments on commit 5696a0c

Please sign in to comment.