Class: RSpec::Matchers::BuiltIn::Compound::NestedEvaluator Private
- Inherits:
-
Object
- Object
- RSpec::Matchers::BuiltIn::Compound::NestedEvaluator
- Defined in:
- lib/rspec/matchers/built_in/compound.rb
Overview
This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.
Normally, we evaluate the matching sequentially. For an expression like expect(x).to foo.and bar
, this becomes:
expect(x).to foo expect(x).to bar
For block expectations, we need to nest them instead, so that expect { x }.to foo.and bar
becomes:
expect { expect { x }.to foo }.to bar
This is necessary so that the expect
block is only executed once.
Instance Method Summary collapse
-
#initialize(actual, matcher_1, matcher_2) ⇒ NestedEvaluator
constructor
private
A new instance of NestedEvaluator.
- #matcher_matches?(matcher) ⇒ Boolean private
Constructor Details
#initialize(actual, matcher_1, matcher_2) ⇒ NestedEvaluator
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of NestedEvaluator.
143 144 145 146 147 148 149 150 151 152 153 154 |
# File 'lib/rspec/matchers/built_in/compound.rb', line 143 def initialize(actual, matcher_1, matcher_2) @actual = actual @matcher_1 = matcher_1 @matcher_2 = matcher_2 @match_results = {} inner, outer = order_block_matchers @match_results[outer] = outer.matches?(Proc.new do |*args| @match_results[inner] = inner.matches?(inner_matcher_block(args)) end) end |
Instance Method Details
#matcher_matches?(matcher) ⇒ Boolean
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
156 157 158 |
# File 'lib/rspec/matchers/built_in/compound.rb', line 156 def matcher_matches?(matcher) @match_results.fetch(matcher) end |