From b3518a838e9b19df5c1019846d1bcaca4ddc389e Mon Sep 17 00:00:00 2001 From: Chris Arcand Date: Mon, 19 Feb 2018 10:47:39 -0600 Subject: [PATCH] Remove custom have_attributes matcher This removes our custom have_attributes matcher which overrides RSpec's default one. Ours added some functionality that doesn't need to exist and can be done with other matchers like `include`. Basically: * Use `expect(thing).to include()` for collections, like hashes (most common offense we use this custom one for). https://relishapp.com/rspec/rspec-expectations/v/3-7/docs/built-in-matchers/include-matcher * Use `expect(thing).to have_attributes()` for other objects that actually have methods for the things you're checking. Models, for example. https://relishapp.com/rspec/rspec-expectations/docs/built-in-matchers/have-attributes-matcher --- .../custom_matchers/have_attributes.rb | 59 ------------------- 1 file changed, 59 deletions(-) delete mode 100644 spec/support/custom_matchers/have_attributes.rb diff --git a/spec/support/custom_matchers/have_attributes.rb b/spec/support/custom_matchers/have_attributes.rb deleted file mode 100644 index d3f0e0bec9c..00000000000 --- a/spec/support/custom_matchers/have_attributes.rb +++ /dev/null @@ -1,59 +0,0 @@ -RSpec::Matchers.define :have_attributes do |attrs| - match do |obj| - regexp = /(.*_spec\.rb:\d+)/ - called_from = caller.detect { |line| line =~ regexp } - - if obj.nil? - @err_msg = "Unexpected call to have_attributes on NilClass" - else - @err_msg = nil - attrs.each do |attr, expected| - actual = - if obj.respond_to?(attr) - obj.send(attr) - elsif obj.respond_to?(:[]) && !obj.kind_of?(ActiveRecord::Base) - @array_access_used = true - obj[attr] - else - RuntimeError.new("Unknown attribute '#{attr}'") - end - - matcher = if actual.respond_to?(:acts_like_time?) && expected.respond_to?(:acts_like_time?) - be_within(0.1).of(expected) - elsif expected.kind_of?(RSpec::Matchers::BuiltIn::Match) - match(expected.expected) - else - eq(expected) - end - - unless matcher.matches?(actual) - name_key = [:name, :id, :object_id].detect { |k| obj.respond_to?(k) } - @err_msg ||= "with #{obj.class.name} #{name_key}:#{obj.send(name_key).inspect}\n\n" - @err_msg << "testing attribute: \"#{attr}\"\n#{matcher.failure_message}\n\n" - end - end - end - - - if @array_access_used - puts <<-MESSAGE -\nWARNING: Use of `have_attributes` with array access (:[]) is deprecated and will be removed shortly. -If you're matching attributes in hashes, use appropriate hash matchers instead (`include`, `eq`). -#{"Called from " + called_from if called_from} - MESSAGE - end - @err_msg.nil? - end - - failure_message do |_obj| - @err_msg - end - - failure_message_when_negated do |_obj| - @err_msg - end - - description do - "have the same attributes as passed" - end -end