Sha256: 9cbd06e3add7f3fb552eb58d61d34f3b1cc55f24565399f4adb2b3f722903061

Contents?: true

Size: 1.84 KB

Versions: 44

Compression:

Stored size: 1.84 KB

Contents

# frozen_string_literal: true

module RuboCop
  module RSpec
    # Extracts cop descriptions from YARD docstrings
    class DescriptionExtractor
      def initialize(yardocs)
        @code_objects = yardocs.map(&CodeObject.public_method(:new))
      end

      def to_h
        code_objects
          .select(&:rspec_cop?)
          .map(&:configuration)
          .reduce(:merge)
      end

      private

      attr_reader :code_objects

      # Decorator of a YARD code object for working with documented rspec cops
      class CodeObject
        RSPEC_COP_CLASS_NAME = 'RuboCop::Cop::RSpec::Base'
        RUBOCOP_COP_CLASS_NAME = 'RuboCop::Cop::Base'
        RSPEC_NAMESPACE = 'RuboCop::Cop::RSpec'

        def initialize(yardoc)
          @yardoc = yardoc
        end

        # Test if the YARD code object documents a concrete rspec cop class
        #
        # @return [Boolean]
        def rspec_cop?
          cop_subclass? && !abstract? && rspec_cop_namespace?
        end

        # Configuration for the documented cop that would live in default.yml
        #
        # @return [Hash]
        def configuration
          { cop_name => { 'Description' => description } }
        end

        private

        def cop_name
          Object.const_get(documented_constant).cop_name
        end

        def description
          yardoc.docstring.split("\n\n").first.to_s
        end

        def rspec_cop_namespace?
          documented_constant.start_with?(RSPEC_NAMESPACE)
        end

        def documented_constant
          yardoc.to_s
        end

        def cop_subclass?
          yardoc.superclass.path == RSPEC_COP_CLASS_NAME ||
            yardoc.superclass.path == RUBOCOP_COP_CLASS_NAME
        end

        def abstract?
          yardoc.tags.any? { |tag| tag.tag_name.eql?('abstract') }
        end

        attr_reader :yardoc
      end
    end
  end
end

Version data entries

44 entries across 44 versions & 7 rubygems

Version Path
rubocop-rspec-2.27.0 lib/rubocop/rspec/description_extractor.rb
mlh-rubocop-config-1.0.3 vendor/bundle/ruby/3.2.0/gems/rubocop-rspec-2.26.1/lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.26.1 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.26.0 lib/rubocop/rspec/description_extractor.rb
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/rubocop-rspec-2.22.0/lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.25.0 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.24.1 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.24.0 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.23.2 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.23.1 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.23.0 lib/rubocop/rspec/description_extractor.rb
mlh-rubocop-config-1.0.2 vendor/bundle/ruby/3.2.0/gems/rubocop-rspec-2.22.0/lib/rubocop/rspec/description_extractor.rb
fablicop-1.10.3 vendor/bundle/ruby/3.2.0/gems/rubocop-rspec-2.22.0/lib/rubocop/rspec/description_extractor.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/rubocop-rspec-2.22.0/lib/rubocop/rspec/description_extractor.rb
fablicop-1.10.2 vendor/bundle/ruby/3.2.0/gems/rubocop-rspec-2.22.0/lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.22.0 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.21.0 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.20.0 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.19.0 lib/rubocop/rspec/description_extractor.rb
rubocop-rspec-2.18.1 lib/rubocop/rspec/description_extractor.rb