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

Version Path
gitlab-styles-13.0.2 lib/rubocop/cop/rspec/useless_dynamic_definition.rb
gitlab-styles-13.0.1 lib/rubocop/cop/rspec/useless_dynamic_definition.rb
gitlab-styles-13.0.0 lib/rubocop/cop/rspec/useless_dynamic_definition.rb
gitlab-styles-11.0.0 lib/rubocop/cop/rspec/useless_dynamic_definition.rb
gitlab-styles-10.1.0 lib/rubocop/cop/rspec/useless_dynamic_definition.rb