File: avoid_executing_git.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (62 lines) | stat: -rw-r--r-- 1,559 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# frozen_string_literal: true

module RuboCop
  module Cop
    module Gemspec
      # Checks that `git` is not executed in a vendored gemspec file.
      # In some installed containers, `git` is not available.
      #
      # @example
      #
      #   # bad
      #   Gem::Specification.new do |spec|
      #     spec.test_files = `git ls-files -- test/*`.split("\n")
      #   end
      #
      #   # good
      #   Gem::Specification.new do |spec|
      #     spec.name = 'your_cool_gem_name'
      #     spec.test_files += Dir.glob('test/**/*')
      #   end
      #
      class AvoidExecutingGit < Base
        include RangeHelp

        MSG = 'Do not execute `git` in gemspec.'

        # @!method gem_specification(node)
        def_node_matcher :gem_specification, <<~PATTERN
          (block
            (send
              (const
                (const {cbase nil?} :Gem) :Specification) :new)
            ...)
        PATTERN

        def_node_matcher :send_node?, <<~PATTERN
          send
        PATTERN

        def_node_search :executes_string, <<~PATTERN
          $(xstr (str $_))
        PATTERN

        def on_block(block_node)
          return unless gem_specification(block_node)

          block_node.descendants.each do |node|
            next unless send_node?(node)

            str = executes_string(node)

            str.each do |execute_node, val|
              break unless val.start_with?('git ')

              add_offense(execute_node, message: message)
            end
          end
        end
      end
    end
  end
end