Sha256: 5335b9ccad5eb61589c3be359ee920c5626b6da609a04fd7ea8204086dafe1b7
Contents?: true
Size: 1.18 KB
Versions: 9
Compression:
Stored size: 1.18 KB
Contents
# frozen_string_literal: true module RuboCop module Cop module RSpec # Check for expectations where `be(...)` can replace `eq(...)`. # # The `be` matcher compares by identity while the `eq` matcher compares # using `==`. Booleans and nil can be compared by identity and therefore # the `be` matcher is preferable as it is a more strict test. # # @example # # bad # expect(foo).to eq(true) # expect(foo).to eq(false) # expect(foo).to eq(nil) # # # good # expect(foo).to be(true) # expect(foo).to be(false) # expect(foo).to be(nil) # class BeEq < Base extend AutoCorrector MSG = 'Prefer `be` over `eq`.' RESTRICT_ON_SEND = %i[eq].freeze # @!method eq_type_with_identity?(node) def_node_matcher :eq_type_with_identity?, <<-PATTERN (send nil? :eq {true false nil}) PATTERN def on_send(node) return unless eq_type_with_identity?(node) add_offense(node.loc.selector) do |corrector| corrector.replace(node.loc.selector, 'be') end end end end end end
Version data entries
9 entries across 9 versions & 2 rubygems