96 lines
3.1 KiB
Ruby
Raw Normal View History

2020-10-10 14:16:11 +02:00
# typed: false
# frozen_string_literal: true
require "utils/github/actions"
2018-09-06 08:29:14 +02:00
module Cask
2018-09-04 08:45:48 +01:00
class Cmd
2020-08-19 10:34:07 +02:00
# Implementation of the `brew cask audit` command.
#
# @api private
2017-05-20 19:08:03 +02:00
class Audit < AbstractCommand
2020-10-20 12:03:48 +02:00
extend T::Sig
sig { returns(String) }
2020-08-01 02:30:46 +02:00
def self.description
2020-04-23 21:16:17 +02:00
<<~EOS
Check <cask> for Homebrew coding style violations. This should be run before
2020-08-01 02:30:46 +02:00
submitting a new cask. If no <cask> is provided, checks all locally
2020-04-23 21:16:17 +02:00
available casks. Will exit with a non-zero status if any errors are
found, which can be useful for implementing pre-commit hooks.
EOS
end
2017-05-21 00:15:56 +02:00
2020-08-01 02:30:46 +02:00
def self.parser
super do
switch "--download",
description: "Audit the downloaded file"
switch "--[no-]appcast",
2020-08-01 02:30:46 +02:00
description: "Audit the appcast"
switch "--token-conflicts",
description: "Audit for token conflicts"
switch "--strict",
description: "Run additional, stricter style checks"
switch "--online",
description: "Run additional, slower style checks that require a network connection"
switch "--new-cask",
2020-08-18 16:14:30 +01:00
description: "Run various additional style checks to determine if a new cask is eligible " \
"for Homebrew. This should be used when creating new casks and implies " \
"`--strict` and `--online`"
2020-08-01 02:30:46 +02:00
end
2016-09-24 13:52:43 +02:00
end
2020-10-20 12:03:48 +02:00
sig { void }
2016-09-24 13:52:43 +02:00
def run
2020-08-18 00:23:23 +01:00
require "cask/auditor"
2020-04-23 21:16:17 +02:00
Homebrew.auditing = true
2020-08-01 02:30:46 +02:00
options = {
audit_download: args.download?,
audit_appcast: args.appcast?,
audit_online: args.online?,
audit_strict: args.strict?,
2020-08-01 02:30:46 +02:00
audit_new_cask: args.new_cask?,
audit_token_conflicts: args.token_conflicts?,
2020-08-01 02:30:46 +02:00
quarantine: args.quarantine?,
language: args.language,
}.compact
2020-04-23 21:16:17 +02:00
2020-08-01 02:30:46 +02:00
options[:quarantine] = true if options[:quarantine].nil?
2020-04-23 21:16:17 +02:00
casks = args.named.flat_map do |name|
2020-11-13 10:07:02 -05:00
if File.exist?(name) && name.count("/") != 1
name
else
2020-11-13 10:07:02 -05:00
Tap.fetch(name).cask_files
end
2020-09-29 23:46:30 +02:00
end
casks = casks.map { |c| CaskLoader.load(c, config: Config.from_args(args)) }
casks = Cask.to_a if casks.empty?
failed_casks = casks.reject do |cask|
2020-04-23 21:16:17 +02:00
odebug "Auditing Cask #{cask}"
2020-08-01 02:30:46 +02:00
result = Auditor.audit(cask, **options)
if ENV["GITHUB_ACTIONS"]
cask_path = cask.sourcefile_path
annotations = (result[:warnings].map { |w| [:warning, w] } + result[:errors].map { |e| [:error, e] })
.map { |type, message| GitHub::Actions::Annotation.new(type, message, file: cask_path) }
annotations.each do |annotation|
puts annotation if annotation.relevant?
end
end
result[:errors].empty?
2020-04-23 21:16:17 +02:00
end
2017-05-19 21:07:25 +02:00
return if failed_casks.empty?
2018-09-17 02:45:00 +02:00
2017-05-19 21:07:25 +02:00
raise CaskError, "audit failed for casks: #{failed_casks.join(" ")}"
2016-09-24 13:52:43 +02:00
end
2016-08-18 22:11:42 +03:00
end
end
end