# frozen_string_literal: true module RuboCop module Cop module RSpec # Do not use `expect` in hooks such as `before`. # # @example # # bad # before do # expect(something).to eq 'foo' # end # # # bad # after do # expect_any_instance_of(Something).to receive(:foo) # end # # # good # it do # expect(something).to eq 'foo' # end class ExpectInHook < Base MSG = 'Do not use `%s` in `%s` hook' def_node_search :expectation, Expectations::ALL.send_pattern def on_block(node) return unless hook?(node) return if node.body.nil? expectation(node.body) do |expect| add_offense(expect.loc.selector, message: message(expect, node)) end end private def message(expect, hook) format(MSG, expect: expect.method_name, hook: hook.method_name) end end end end end