Skip to main content

Access the running example

In the context of a custom matcher, you can call helper methods that are available from the current example's example group. This is used, for example, by rspec-rails in order to wrap rails' built-in assertions (which depend on helper methods available in the test context).

Call method defined on example from matcher

Given a file named "example_spec.rb" with:

RSpec::Matchers.define :bar do
match do |_|
foo == "foo"
end
end

RSpec.describe "something" do
def foo
"foo"
end

it "does something" do
expect("foo").to bar
end
end

When I run rspec ./example_spec.rb

Then the output should contain "1 example, 0 failures".

Call method not defined on example from matcher

Given a file named "example_spec.rb" with:

RSpec::Matchers.define :bar do
match do |_|
foo == "foo"
end
end

RSpec.describe "something" do
it "does something" do
expect("foo").to bar
end
end

When I run rspec ./example_spec.rb

Then the output should contain "1 example, 1 failure"

And the output should match /undefined.*method/

And the output should contain "RSpec::Matchers::DSL::Matcher"

And the output should not contain "ExampleGroup".