Sha256: 48f25496b476924bc8135edcf5138151b7b38fd1c4c45f943c55d1d5ad681ed2
Contents?: true
Size: 1.69 KB
Versions: 5
Compression:
Stored size: 1.69 KB
Contents
# frozen_string_literal: true require_relative 'base' module Rubocop module Cop module RSpec # Flags useless dynamic hook/let definitions via `.each`, `.each_key`, or # `.each_value` without defining a wrapping `context` explicitly inside # the loop block. Without it, the let definition will always/only be set # to the final value. # # @example # # # bad # context 'foo' do # [true, false].each do |bool| # before do # stub_something(bool: bool) # end # # let(:foo) { build(:model, bool: bool) } # # it 'works' do # # `bool` is always `false` # end # end # end # # # good # context 'foo' do # [true, false].each do |bool| # context "with bool #{bool}" do # <-- # before do # stub_something(bool: bool) # end # # let(:foo) { build(:model, bool: bool) } # # it 'works' do # # `bool` is `true` and then `false` # end # end # end # end class UselessDynamicDefinition < Base MSG = 'Avoid useless dynamic definitions without `context`.' RESTRICT_ON_SEND = %i[each each_key each_value].freeze def on_send(node) return unless dynamic_definition?(node.parent) add_offense(node.loc.selector) end private def dynamic_definition?(node) group = RuboCop::RSpec::ExampleGroup.new(node) group.lets.any? || group.hooks.any? end end end end end
Version data entries
5 entries across 5 versions & 1 rubygems