Class: RSpec::Matchers::BuiltIn::YieldControl Private

Inherits:
BaseMatcher
  • Object
show all
Defined in:
lib/rspec/matchers/built_in/yield.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.

Provides the implementation for yield_control. Not intended to be instantiated directly.

Constant Summary

Constant Summary

Constants inherited from BaseMatcher

BaseMatcher::UNDEFINED

Instance Method Summary (collapse)

Methods inherited from BaseMatcher

#description, #diffable?, #expects_call_stack_jump?, #match_unless_raises

Methods included from Composable

#===, #and, #description_of, #or, should_enumerate?, surface_descriptions_in, #values_match?

Constructor Details

- (YieldControl) initialize

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 YieldControl

98
99
100
# File 'lib/rspec/matchers/built_in/yield.rb', line 98
def initialize
  at_least(:once)
end

Instance Method Details

- (Object) at_least(number)

Specifies the minimum number of times the method is expected to yield

139
140
141
142
# File 'lib/rspec/matchers/built_in/yield.rb', line 139
def at_least(number)
  set_expected_yields_count(:>=, number)
  self
end

- (Object) at_most(number)

Specifies the maximum number of times the method is expected to yield

132
133
134
135
# File 'lib/rspec/matchers/built_in/yield.rb', line 132
def at_most(number)
  set_expected_yields_count(:<=, number)
  self
end

- (Object) exactly(number)

Specifies that the method is expected to yield the given number of times.

125
126
127
128
# File 'lib/rspec/matchers/built_in/yield.rb', line 125
def exactly(number)
  set_expected_yields_count(:==, number)
  self
end

- (String) failure_message

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:

  • (String)
165
166
167
# File 'lib/rspec/matchers/built_in/yield.rb', line 165
def failure_message
  'expected given block to yield control' + failure_reason
end

- (String) failure_message_when_negated

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:

  • (String)
171
172
173
# File 'lib/rspec/matchers/built_in/yield.rb', line 171
def failure_message_when_negated
  'expected given block not to yield control' + failure_reason
end

- (Object) once

Specifies that the method is expected to yield once.

104
105
106
107
# File 'lib/rspec/matchers/built_in/yield.rb', line 104
def once
  exactly(1)
  self
end

- (Object) thrice

Specifies that the method is expected to yield thrice.

118
119
120
121
# File 'lib/rspec/matchers/built_in/yield.rb', line 118
def thrice
  exactly(3)
  self
end

- (Object) times

No-op. Provides syntactic sugar.

146
147
148
# File 'lib/rspec/matchers/built_in/yield.rb', line 146
def times
  self
end

- (Object) twice

Specifies that the method is expected to yield twice.

111
112
113
114
# File 'lib/rspec/matchers/built_in/yield.rb', line 111
def twice
  exactly(2)
  self
end