2023-04-03 22:27:46 +08:00
|
|
|
# typed: strict
|
2023-04-03 20:36:45 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require "cli/parser"
|
2023-04-05 01:18:11 +08:00
|
|
|
require "test_runner_formula"
|
2023-04-05 03:52:26 +08:00
|
|
|
require "github_runner_matrix"
|
2023-04-03 20:36:45 +08:00
|
|
|
|
|
|
|
module Homebrew
|
2023-04-03 22:27:46 +08:00
|
|
|
extend T::Sig
|
2023-04-03 20:36:45 +08:00
|
|
|
|
2023-04-03 22:27:46 +08:00
|
|
|
sig { returns(Homebrew::CLI::Parser) }
|
|
|
|
def self.determine_test_runners_args
|
2023-04-03 20:36:45 +08:00
|
|
|
Homebrew::CLI::Parser.new do
|
|
|
|
usage_banner <<~EOS
|
|
|
|
`determine-test-runners` <testing-formulae> [<deleted-formulae>]
|
|
|
|
|
|
|
|
Determines the runners used to test formulae or their dependents.
|
|
|
|
EOS
|
2023-04-04 23:58:32 +08:00
|
|
|
switch "--eval-all",
|
|
|
|
description: "Evaluate all available formulae, whether installed or not, to determine testing " \
|
|
|
|
"dependents."
|
2023-04-03 20:36:45 +08:00
|
|
|
switch "--dependents",
|
2023-04-04 23:58:32 +08:00
|
|
|
description: "Determine runners for testing dependents. Requires `--eval-all` or `HOMEBREW_EVAL_ALL`."
|
2023-04-03 20:36:45 +08:00
|
|
|
|
|
|
|
named_args min: 1, max: 2
|
|
|
|
|
|
|
|
hide_from_man_page!
|
|
|
|
end
|
|
|
|
end
|
2023-04-05 01:09:56 +08:00
|
|
|
|
2023-04-04 13:54:35 +08:00
|
|
|
sig {
|
|
|
|
params(
|
2023-04-05 03:52:26 +08:00
|
|
|
version: String,
|
2023-04-05 01:09:56 +08:00
|
|
|
arch: Symbol,
|
2023-04-05 03:52:26 +08:00
|
|
|
ephemeral: T::Boolean,
|
|
|
|
ephemeral_suffix: T.nilable(String),
|
|
|
|
).returns(T::Hash[Symbol, T.any(String, T::Boolean)])
|
2023-04-04 13:54:35 +08:00
|
|
|
}
|
2023-04-05 03:52:26 +08:00
|
|
|
def self.runner_spec(version, arch:, ephemeral:, ephemeral_suffix: nil)
|
|
|
|
case arch
|
|
|
|
when :arm64 then { runner: "#{version}-arm64#{ephemeral_suffix}", clean: !ephemeral }
|
|
|
|
when :x86_64 then { runner: "#{version}#{ephemeral_suffix}", clean: !ephemeral }
|
|
|
|
else raise "Unexpected arch: #{arch}"
|
2023-04-04 13:54:35 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-04-03 22:27:46 +08:00
|
|
|
sig { void }
|
|
|
|
def self.determine_test_runners
|
2023-04-04 13:54:35 +08:00
|
|
|
args = determine_test_runners_args.parse
|
2023-04-04 16:19:46 +08:00
|
|
|
|
2023-04-04 23:58:32 +08:00
|
|
|
eval_all = args.eval_all? || Homebrew::EnvConfig.eval_all?
|
|
|
|
|
|
|
|
odie "`--dependents` requires `--eval-all` or `HOMEBREW_EVAL_ALL`!" if args.dependents? && !eval_all
|
|
|
|
|
2023-04-04 16:19:46 +08:00
|
|
|
Formulary.enable_factory_cache!
|
|
|
|
|
2023-04-04 13:54:35 +08:00
|
|
|
testing_formulae = args.named.first.split(",")
|
2023-04-05 03:52:26 +08:00
|
|
|
testing_formulae.map! { |name| TestRunnerFormula.new(Formulary.factory(name), eval_all: eval_all) }
|
2023-04-04 13:54:35 +08:00
|
|
|
.freeze
|
|
|
|
deleted_formulae = args.named.second&.split(",")
|
|
|
|
|
2023-04-05 03:52:26 +08:00
|
|
|
linux_runner = ENV.fetch("HOMEBREW_LINUX_RUNNER") { raise "HOMEBREW_LINUX_RUNNER is not defined" }
|
|
|
|
linux_cleanup = ENV.fetch("HOMEBREW_LINUX_CLEANUP") { raise "HOMEBREW_LINUX_CLEANUP is not defined" }
|
|
|
|
github_run_id = ENV.fetch("GITHUB_RUN_ID") { raise "GITHUB_RUN_ID is not defined" }
|
|
|
|
github_run_attempt = ENV.fetch("GITHUB_RUN_ATTEMPT") { raise "GITHUB_RUN_ATTEMPT is not defined" }
|
|
|
|
github_output = ENV.fetch("GITHUB_OUTPUT") { raise "GITHUB_OUTPUT is not defined" }
|
2023-04-04 13:54:35 +08:00
|
|
|
|
|
|
|
linux_runner_spec = {
|
|
|
|
runner: linux_runner,
|
|
|
|
container: {
|
|
|
|
image: "ghcr.io/homebrew/ubuntu22.04:master",
|
|
|
|
options: "--user=linuxbrew -e GITHUB_ACTIONS_HOMEBREW_SELF_HOSTED",
|
|
|
|
},
|
|
|
|
workdir: "/github/home",
|
|
|
|
timeout: 4320,
|
|
|
|
cleanup: linux_cleanup == "true",
|
|
|
|
}
|
2023-04-04 16:19:46 +08:00
|
|
|
ephemeral_suffix = "-#{github_run_id}-#{github_run_attempt}"
|
|
|
|
|
2023-04-05 03:52:26 +08:00
|
|
|
available_runners = []
|
|
|
|
available_runners << { platform: :linux, arch: :x86_64, runner_spec: linux_runner_spec, macos_version: nil }
|
|
|
|
|
2023-04-05 01:09:56 +08:00
|
|
|
MacOSVersions::SYMBOLS.each_value do |version|
|
2023-04-04 23:10:51 +08:00
|
|
|
macos_version = OS::Mac::Version.new(version)
|
2023-04-04 16:19:46 +08:00
|
|
|
next if macos_version.outdated_release? || macos_version.prerelease?
|
|
|
|
|
2023-04-05 03:52:26 +08:00
|
|
|
spec = runner_spec(version, arch: :x86_64, ephemeral: true, ephemeral_suffix: ephemeral_suffix)
|
|
|
|
available_runners << { platform: :macos, arch: :x86_64, runner_spec: spec, macos_version: macos_version }
|
2023-04-04 13:54:35 +08:00
|
|
|
|
2023-04-05 03:52:26 +08:00
|
|
|
# Use bare metal runner when testing dependents on ARM64 Monterey.
|
|
|
|
if (macos_version >= :ventura && args.dependents?) || macos_version >= :monterey
|
|
|
|
spec = runner_spec(version, arch: :arm64, ephemeral: true, ephemeral_suffix: ephemeral_suffix)
|
|
|
|
available_runners << { platform: :macos, arch: :arm64, runner_spec: spec, macos_version: macos_version }
|
2023-04-04 16:19:46 +08:00
|
|
|
elsif macos_version >= :big_sur
|
2023-04-05 03:52:26 +08:00
|
|
|
spec = runner_spec(version, arch: :arm64, ephemeral: false)
|
|
|
|
available_runners << { platform: :macos, arch: :arm64, runner_spec: spec, macos_version: macos_version }
|
2023-04-04 13:54:35 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-04-05 03:52:26 +08:00
|
|
|
runner_matrix = GitHubRunnerMatrix.new(
|
|
|
|
available_runners,
|
|
|
|
testing_formulae,
|
|
|
|
deleted_formulae,
|
|
|
|
dependent_matrix: args.dependents?,
|
|
|
|
)
|
|
|
|
runners = runner_matrix.active_runners
|
|
|
|
|
2023-04-04 13:54:35 +08:00
|
|
|
if !args.dependents? && runners.blank?
|
|
|
|
# If there are no tests to run, add a runner that is meant to do nothing
|
|
|
|
# to support making the `tests` job a required status check.
|
|
|
|
runners << { runner: "ubuntu-latest", no_op: true }
|
|
|
|
end
|
|
|
|
|
|
|
|
File.open(github_output, "a") do |f|
|
|
|
|
f.puts("runners=#{runners.to_json}")
|
|
|
|
f.puts("runners_present=#{runners.present?}")
|
|
|
|
end
|
2023-04-03 20:36:45 +08:00
|
|
|
end
|
|
|
|
end
|