Class: RSpec::Matchers::BuiltIn::ThrowSymbol Private
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Instance Chain: | |
| Inherits: | Object | 
| Defined in: | rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb | 
Overview
Provides the implementation for RSpec::Matchers#throw_symbol. Not intended to be instantiated directly.
Class Method Summary
- .new(expected_symbol = nil, expected_arg = nil) ⇒ ThrowSymbol constructor Internal use only
Instance Attribute Summary
- #expects_call_stack_jump? ⇒ Boolean readonly Internal use only
- 
    
      #supports_block_expectations?  ⇒ True 
    
    readonly
    Internal use only
    Indicates this matcher matches against a block. 
- #supports_value_expectations? ⇒ Boolean readonly Internal use only
Instance Method Summary
- #description ⇒ String Internal use only
- #does_not_match?(given_proc) ⇒ Boolean Internal use only
- #failure_message ⇒ String Internal use only
- #failure_message_when_negated ⇒ String Internal use only
- #matches?(given_proc) ⇒ Boolean Internal use only
- #actual_result private Internal use only
- #caught private Internal use only
- #expected(symbol_desc = 'a Symbol') private Internal use only
- #throw_description(symbol, arg) private Internal use only
::RSpec::Matchers::Composable - Included
| #& | Alias for Composable#and. | 
| #=== | Delegates to #matches?. | 
| #and | Creates a compound  | 
| #description_of | Returns the description of the given object in a way that is aware of composed matchers. | 
| #or | Creates a compound  | 
| #values_match? | This provides a generic way to fuzzy-match an expected value against an actual value. | 
| #| | Alias for Composable#or. | 
| #should_enumerate? | We should enumerate arrays as long as they are not recursive. | 
| #surface_descriptions_in | Transforms the given data structure (typically a hash or array) into a new data structure that, when  | 
| #unreadable_io?, | |
| #with_matchers_cloned | Historically, a single matcher instance was only checked against a single value. | 
Instance Attribute Details
    #expects_call_stack_jump?  ⇒ Boolean  (readonly)
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 103
def expects_call_stack_jump? true end
    #supports_block_expectations?  ⇒ True  (readonly)
  
Indicates this matcher matches against a block.
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 93
def supports_block_expectations? true end
    #supports_value_expectations?  ⇒ Boolean  (readonly)
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 98
def supports_value_expectations? false end
Instance Method Details
#actual_result (private)
[ GitHub ]# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 109
def actual_result return "but was not a block" unless Proc === @block "got #{caught}" end
#caught (private)
[ GitHub ]# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 118
def caught throw_description(@caught_symbol || 'nothing', @caught_arg) end
    #description  ⇒ String 
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 86
def description "throw #{expected}" end
    #does_not_match?(given_proc)  ⇒ Boolean 
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 68
def does_not_match?(given_proc) !matches?(given_proc) && Proc === given_proc end
#expected(symbol_desc = 'a Symbol') (private)
[ GitHub ]# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 114
def expected(symbol_desc='a Symbol') throw_description(@expected_symbol || symbol_desc, @expected_arg) end
    #failure_message  ⇒ String 
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 74
def "expected #{expected} to be thrown, #{actual_result}" end
    #failure_message_when_negated  ⇒ String 
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 80
def "expected #{expected('no Symbol')}#{' not' if @expected_symbol} to be thrown, #{actual_result}" end
    #matches?(given_proc)  ⇒ Boolean 
  
# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 18
def matches?(given_proc) @block = given_proc return false unless Proc === given_proc begin if @expected_symbol.nil? given_proc.call else @caught_arg = catch :proc_did_not_throw_anything do catch @expected_symbol do given_proc.call throw :proc_did_not_throw_anything, :nothing_thrown end end if @caught_arg == :nothing_thrown @caught_arg = nil else @caught_symbol = @expected_symbol end end # Ruby 1.8 uses NameError with `symbol' # Ruby 1.9 uses ArgumentError with :symbol rescue NameError, ArgumentError => e unless (match_data = e..match(/uncaught throw (`|\:)([a-zA-Z0-9_]*)(')?/)) other_exception = e raise end @caught_symbol = match_data.captures[1].to_sym rescue => other_exception raise ensure # rubocop:disable Lint/EnsureReturn unless other_exception if @expected_symbol.nil? return !!@caught_symbol else if @expected_arg.nil? return @caught_symbol == @expected_symbol else return (@caught_symbol == @expected_symbol) && values_match?(@expected_arg, @caught_arg) end end end # rubocop:enable Lint/EnsureReturn end end
#throw_description(symbol, arg) (private)
[ GitHub ]# File 'rspec-expectations/lib/rspec/matchers/built_in/throw_symbol.rb', line 122
def throw_description(symbol, arg) symbol_description = symbol.is_a?(String) ? symbol : description_of(symbol) arg_description = if arg " with #{description_of arg}" elsif @expected_arg && @caught_symbol == @expected_symbol " with no argument" else "" end symbol_description + arg_description end