Sha256: 53655db13c82ba84f6a559b641103faa01d2c4a2237930749d20597b09277176

Contents?: true

Size: 1.26 KB

Versions: 8

Compression:

Stored size: 1.26 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module RSpec
      # Check that before/after(:all) isn't being used.
      #
      # @example
      #   # bad
      #   #
      #   # Faster but risk of state leaking between examples
      #   #
      #   describe MyClass do
      #     before(:all) { Widget.create }
      #     after(:all) { Widget.delete_all }
      #   end
      #
      #   # good
      #   #
      #   # Slower but examples are properly isolated
      #   #
      #   describe MyClass do
      #     before(:each) { Widget.create }
      #     after(:each) { Widget.delete_all }
      #   end
      class BeforeAfterAll < Cop
        MSG = 'Beware of using `%<hook>s` as it may cause state to leak '\
              'between tests. If you are using `rspec-rails`, and '\
              '`use_transactional_fixtures` is enabled, then records created '\
              'in `%<hook>s` are not automatically rolled back.'.freeze

        def_node_matcher :before_or_after_all, <<-PATTERN
          $(send _ {:before :after} (sym {:all :context}))
        PATTERN

        def on_send(node)
          before_or_after_all(node) do |hook|
            add_offense(node, :expression, format(MSG, hook: hook.source))
          end
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
rubocop-rspec-1.18.0 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.17.1 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.17.0 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.16.0 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.15.1 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.15.0 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.14.0 lib/rubocop/cop/rspec/before_after_all.rb
rubocop-rspec-1.13.0 lib/rubocop/cop/rspec/before_after_all.rb