lib/rubocop/cop/minitest/skip_without_reason.rb
# frozen_string_literal: true module RuboCop module Cop module Minitest # Checks for skipped tests missing the skipping reason. # # @example # # bad # skip # skip('') # # # bad # if condition? # skip # else # skip # end # # # good # skip("Reason why the test was skipped") # # # good # skip if condition? # class SkipWithoutReason < Base MSG = 'Add a reason explaining why the test is skipped.' RESTRICT_ON_SEND = %i[skip].freeze def on_send(node) return if node.receiver || !blank_argument?(node) conditional_node = conditional_parent(node) return if conditional_node && !only_skip_branches?(conditional_node) return if node.parent&.resbody_type? add_offense(node) end private def blank_argument?(node) message = node.first_argument message.nil? || (message.str_type? && message.value == '') end def conditional_parent(node) return unless (parent = node.parent) if parent.if_type? || parent.case_type? parent elsif parent.when_type? parent.parent end end def only_skip_branches?(node) branches = node.branches.compact branches.size > 1 && branches.all? { |branch| branch.send_type? && branch.method?(:skip) } end end end end end