123456789_123456789_123456789_123456789_123456789_

Class: RSpec::Matchers::BuiltIn::BaseMatcher Private

Do not use. This class is for internal use only.
Relationships & Source Files
Namespace Children
Modules:
Extension / Inclusion / Inheritance Descendants
Subclasses:
RSpec::Matchers::BuiltIn::All, RSpec::Matchers::BuiltIn::Be, RSpec::Matchers::BuiltIn::BeAKindOf, RSpec::Matchers::BuiltIn::BeAnInstanceOf, RSpec::Matchers::BuiltIn::BeBetween, RSpec::Matchers::BuiltIn::BeComparedTo, RSpec::Matchers::BuiltIn::BeFalsey, RSpec::Matchers::BuiltIn::BeNil, RSpec::Matchers::BuiltIn::BePredicate, RSpec::Matchers::BuiltIn::BeTruthy, RSpec::Matchers::BuiltIn::BeWithin, RSpec::Matchers::BuiltIn::Change, RSpec::Matchers::BuiltIn::ChangeFromValue, RSpec::Matchers::BuiltIn::ChangeRelatively, RSpec::Matchers::BuiltIn::ChangeToValue, RSpec::Matchers::BuiltIn::Compound, RSpec::Matchers::BuiltIn::ContainExactly, RSpec::Matchers::BuiltIn::Cover, RSpec::Matchers::BuiltIn::DynamicPredicate, RSpec::Matchers::BuiltIn::EndWith, RSpec::Matchers::BuiltIn::Eq, RSpec::Matchers::BuiltIn::Eql, RSpec::Matchers::BuiltIn::Equal, RSpec::Matchers::BuiltIn::Exist, RSpec::Matchers::BuiltIn::Has, RSpec::Matchers::BuiltIn::HaveAttributes, RSpec::Matchers::BuiltIn::Include, RSpec::Matchers::BuiltIn::Match, RSpec::Matchers::BuiltIn::Output, RSpec::Matchers::BuiltIn::RespondTo, RSpec::Matchers::BuiltIn::Satisfy, RSpec::Matchers::BuiltIn::SpecificValuesChange, RSpec::Matchers::BuiltIn::StartOrEndWith, RSpec::Matchers::BuiltIn::StartWith, RSpec::Matchers::BuiltIn::YieldControl, RSpec::Matchers::BuiltIn::YieldSuccessiveArgs, RSpec::Matchers::BuiltIn::YieldWithArgs, RSpec::Matchers::BuiltIn::YieldWithNoArgs, RSpec::Rails::Matchers::BeValid, Compound::And, Compound::Or, RSpec::Rails::Matchers::ActionCable::HaveBroadcastedTo, RSpec::Rails::Matchers::ActionCable::HaveStream
Super Chains via Extension / Inclusion / Inheritance
Instance Chain:
Inherits: Object
Defined in: rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb

Overview

Used internally as a base class for matchers that ship with rspec-expectations and rspec-rails.

Warning:

This class is for internal use, and subject to change without notice. We strongly recommend that you do not base your custom matchers on this class. If/when this changes, we will announce it and remove this warning.

Constant Summary

Class Method Summary

Instance Attribute Summary

StringEncodingFormatting - Included

Instance Method Summary

DefaultFailureMessages - Included

#failure_message

Provides a good generic failure message.

#failure_message_when_negated

Provides a good generic negative failure message.

StringEncodingFormatting - Included

#format_encoding

Formats a String’s encoding as a human readable string :nocov:

HashFormatting - Included

#improve_hash_formatting

‘{ :a => 5, :b => 2 }.inspect` produces:

::RSpec::Matchers::Composable - Included

#&

Alias for Composable#and.

#===

Delegates to #matches?.

#and

Creates a compound and expectation.

#description_of

Returns the description of the given object in a way that is aware of composed matchers.

#or

Creates a compound or expectation.

#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 #inspect is called on it, will provide descriptions of any contained matchers rather than the normal #inspect output.

#unreadable_io?,
#with_matchers_cloned

Historically, a single matcher instance was only checked against a single value.

Class Method Details

.matcher_name

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 102

def self.matcher_name
  @matcher_name ||= underscore(name.split('::').last)
end

.underscore(camel_cased_word) (private)

Borrowed from ActiveSupport.

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 117

def self.underscore(camel_cased_word)
  word = camel_cased_word.to_s.dup
  word.gsub!(/([A-Z]+)([A-Z][a-z])/, '\1_\2')
  word.gsub!(/([a-z\d])([A-Z])/, '\1_\2')
  word.tr!('-', '_')
  word.downcase!
  word
end

Instance Attribute Details

#actual (readonly)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 23

attr_reader :actual, :expected, :rescued_exception

#diffable?Boolean (readonly)

::RSpec::Matchers are not diffable by default. Override this to make your subclass diffable.

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 69

def diffable?
  false
end

#expected (readonly)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 23

attr_reader :actual, :expected, :rescued_exception

#expects_call_stack_jump?Boolean (readonly)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 87

def expects_call_stack_jump?
  false
end

#matcher_name (rw)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 107

def matcher_name
  if defined?(@matcher_name)
    @matcher_name
  else
    self.class.matcher_name
  end
end

#matcher_name=(value) (rw)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 26

attr_writer :matcher_name

#rescued_exception (readonly)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 23

attr_reader :actual, :expected, :rescued_exception

#supports_block_expectations?Boolean (readonly)

Most matchers are value matchers (i.e. meant to work with ‘expect(value)`) rather than block matchers (i.e. meant to work with `expect { }`), so this defaults to false. Block matchers must override this to return true.

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 77

def supports_block_expectations?
  false
end

#supports_value_expectations?Boolean (readonly)

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 82

def supports_value_expectations?
  true
end

Instance Method Details

#actual_formatted

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 97

def actual_formatted
  RSpec::Support::ObjectFormatter.format(@actual)
end

#descriptionString

Generates a description using ::RSpec::Matchers::EnglishPhrasing.

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 60

def description
  desc = EnglishPhrasing.split_words(self.class.matcher_name)
  desc << EnglishPhrasing.list(@expected) if defined?(@expected)
  desc
end

#expected_formatted

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 92

def expected_formatted
  RSpec::Support::ObjectFormatter.format(@expected)
end

#match_unless_raises(*exceptions)

Used to wrap a block of code that will indicate failure by raising one of the named exceptions.

This is used by rspec-rails for some of its matchers that wrap rails’ assertions.

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 47

def match_unless_raises(*exceptions)
  exceptions.unshift Exception if exceptions.empty?
  begin
    yield
    true
  rescue *exceptions => @rescued_exception
    false
  end
end

#matches?(actual) ⇒ Boolean

Indicates if the match is successful. Delegates to RSpec::Matchers#match, which should be defined on a subclass. Takes care of consistently initializing the #actual attribute.

[ GitHub ]

  
# File 'rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb', line 36

def matches?(actual)
  @actual = actual
  match(expected, actual)
end