module RSpec::Matchers::Pretty
def _pretty_print(array)
def _pretty_print(array) RSpec.deprecate("`RSpec::Matchers::Pretty#_pretty_print`", :replacement => "`RSpec::Matchers::Pretty#to_sentence`") result = "" array.each_with_index do |item, index| if index < (array.length - 2) result << "#{item.inspect}, " elsif index < (array.length - 1) result << "#{item.inspect} and " else result << "#{item.inspect}" end end result end
def expected_to_sentence
def expected_to_sentence RSpec.deprecate("`RSpec::Matchers::Pretty#expected_to_sentence`", :replacement => "`RSpec::Matchers::Pretty#to_sentence(expected)`") to_sentence(@expected) if defined?(@expected) end
def is_matcher_with_description?(object)
def is_matcher_with_description?(object) RSpec::Matchers.is_a_matcher?(object) && object.respond_to?(:description) end
def name
def name defined?(@name) ? @name : underscore(self.class.name.split("::").last) end
def name_to_sentence
def name_to_sentence split_words(name) end
def split_words(sym)
def split_words(sym) sym.to_s.gsub(/_/,' ') end
def to_sentence(words)
def to_sentence(words) return "" unless words words = Array(words).map { |w| to_word(w) } case words.length when 0 "" when 1 " #{words[0]}" when 2 " #{words[0]} and #{words[1]}" else " #{words[0...-1].join(', ')}, and #{words[-1]}" end end
def to_word(item)
def to_word(item) is_matcher_with_description?(item) ? item.description : item.inspect end
def underscore(camel_cased_word)
def 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