brew/Library/Homebrew/utils/backtrace.rb
Mike McQuaid cc03340af3
Reduce Homebrew/brew CI warnings
- Remove a bunch of non-actionable/unnecessary noise in GitHub Actions
  CI.
- Limit number of threads used to generate analytics API data to avoid
  reproducible failures producing errors and requiring retries.
- Move to Debian Old Stable for testing non-system `glibc`.
- Remove unneeded core taps/updates.
- Improve naming of CI jobs to clarify purpose i.e. we're testing
  things work on Linux, not Ubuntu specifically.
- Remove dedicated non-online/non-generic Linux `brew tests` jobs from
  3 to 1.

Co-authored-by: Rylan Polster <rslpolster@gmail.com>
2025-06-09 12:47:22 +01:00

56 lines
1.8 KiB
Ruby

# typed: strict
# frozen_string_literal: true
module Utils
module Backtrace
@print_backtrace_message = T.let(false, T::Boolean)
# Cleans `sorbet-runtime` gem paths from the backtrace unless...
# 1. `verbose` is set
# 2. first backtrace line starts with `sorbet-runtime`
# - This implies that the error is related to Sorbet.
sig { params(error: Exception).returns(T.nilable(T::Array[String])) }
def self.clean(error)
backtrace = error.backtrace
return backtrace if Context.current.verbose?
return backtrace if backtrace.blank?
return backtrace if backtrace.fetch(0).start_with?(sorbet_runtime_path)
old_backtrace_length = backtrace.length
backtrace.reject { |line| line.start_with?(sorbet_runtime_path) }
.tap { |new_backtrace| print_backtrace_message if old_backtrace_length > new_backtrace.length }
end
sig { returns(String) }
def self.sorbet_runtime_path
@sorbet_runtime_path ||= T.let("#{Gem.paths.home}/gems/sorbet-runtime", T.nilable(String))
end
sig { void }
def self.print_backtrace_message
return if @print_backtrace_message
# This is just unactionable noise in GitHub Actions.
opoo_outside_github_actions "Removed Sorbet lines from backtrace!"
puts "Rerun with `--verbose` to see the original backtrace" unless Homebrew::EnvConfig.no_env_hints?
@print_backtrace_message = true
end
sig { params(error: Exception).returns(T.nilable(String)) }
def self.tap_error_url(error)
backtrace = error.backtrace
return if backtrace.blank?
backtrace.each do |line|
if (tap = line.match(%r{/Library/Taps/([^/]+/[^/]+)/}))
return "https://github.com/#{tap[1]}/issues/new"
end
end
nil
end
end
end