Support --dependents
flag on macOS
This commit is contained in:
parent
15061cec70
commit
506f6c81a7
@ -13,11 +13,11 @@ class TestRunnerFormula
|
|||||||
sig { returns(Formula) }
|
sig { returns(Formula) }
|
||||||
attr_reader :formula
|
attr_reader :formula
|
||||||
|
|
||||||
sig { params(name: String).void }
|
sig { params(formula: Formula).void }
|
||||||
def initialize(name)
|
def initialize(formula)
|
||||||
@name = T.let(name, String)
|
@formula = T.let(formula, Formula)
|
||||||
@formula = T.let(Formula[name], Formula)
|
@name = T.let(formula.name, String)
|
||||||
@dependent_hash = T.let({}, T::Hash[T::Boolean, T::Array[TestRunnerFormula]])
|
@dependent_hash = T.let({}, T::Hash[Symbol, T::Array[TestRunnerFormula]])
|
||||||
freeze
|
freeze
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -54,6 +54,19 @@ class TestRunnerFormula
|
|||||||
|
|
||||||
macos_version.public_send(requirement.comparator, requirement.version)
|
macos_version.public_send(requirement.comparator, requirement.version)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
sig { params(cache_key: Symbol).returns(T::Array[TestRunnerFormula]) }
|
||||||
|
def dependents(cache_key)
|
||||||
|
# TODO: Check that `--eval-all` or `HOMEBREW_EVAL_ALL` is set.
|
||||||
|
@dependent_hash[cache_key] ||= with_env(HOMEBREW_EVAL_ALL: "1") do
|
||||||
|
Formula.all
|
||||||
|
.select { |candidate_f| candidate_f.deps.map(&:name).include?(name) }
|
||||||
|
.map { |f| TestRunnerFormula.new(f) }
|
||||||
|
.freeze
|
||||||
|
end
|
||||||
|
|
||||||
|
@dependent_hash.fetch(cache_key)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
module Homebrew
|
module Homebrew
|
||||||
@ -68,25 +81,39 @@ module Homebrew
|
|||||||
Determines the runners used to test formulae or their dependents.
|
Determines the runners used to test formulae or their dependents.
|
||||||
EOS
|
EOS
|
||||||
switch "--dependents",
|
switch "--dependents",
|
||||||
description: "Determine runners for testing dependents. (requires Linux)"
|
description: "Determine runners for testing dependents."
|
||||||
|
|
||||||
named_args min: 1, max: 2
|
named_args min: 1, max: 2
|
||||||
|
|
||||||
hide_from_man_page!
|
hide_from_man_page!
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
sig {
|
sig {
|
||||||
params(
|
params(
|
||||||
_testing_formulae: T::Array[TestRunnerFormula],
|
testing_formulae: T::Array[TestRunnerFormula],
|
||||||
reject_platform: T.nilable(Symbol),
|
reject_platform: T.nilable(Symbol),
|
||||||
reject_arch: T.nilable(Symbol),
|
reject_arch: T.nilable(Symbol),
|
||||||
select_macos_version: T.nilable(MacOS::Version),
|
select_macos_version: T.nilable(MacOS::Version),
|
||||||
).void
|
).returns(T::Boolean)
|
||||||
}
|
}
|
||||||
def self.formulae_have_untested_dependents?(_testing_formulae, reject_platform:,
|
def self.formulae_have_untested_dependents?(testing_formulae, reject_platform:, reject_arch:, select_macos_version:)
|
||||||
reject_arch:, select_macos_version:)
|
testing_formulae.any? do |formula|
|
||||||
odie "`--dependents` is supported only on Linux!"
|
# If the formula has a platform/arch/macOS version requirement, then its
|
||||||
|
# dependents don't need to be tested if these requirements are not satisfied.
|
||||||
|
next false if reject_platform && formula.send(:"#{reject_platform}_only?")
|
||||||
|
next false if reject_arch && formula.send(:"#{reject_arch}_only?")
|
||||||
|
next false if select_macos_version && !formula.compatible_with?(select_macos_version)
|
||||||
|
|
||||||
|
compatible_dependents = formula.dependents(:"#{reject_platform}_#{reject_arch}_#{select_macos_version}").dup
|
||||||
|
|
||||||
|
compatible_dependents.reject! { |dependent_f| dependent_f.send(:"#{reject_arch}_only?") } if reject_arch
|
||||||
|
compatible_dependents.reject! { |dependent_f| dependent_f.send(:"#{reject_platform}_only?") } if reject_platform
|
||||||
|
if select_macos_version
|
||||||
|
compatible_dependents.select! { |dependent_f| dependent_f.compatible_with?(select_macos_version) }
|
||||||
|
end
|
||||||
|
|
||||||
|
(compatible_dependents - testing_formulae).present?
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
sig {
|
sig {
|
||||||
@ -128,8 +155,11 @@ module Homebrew
|
|||||||
sig { void }
|
sig { void }
|
||||||
def self.determine_test_runners
|
def self.determine_test_runners
|
||||||
args = determine_test_runners_args.parse
|
args = determine_test_runners_args.parse
|
||||||
|
|
||||||
|
Formulary.enable_factory_cache!
|
||||||
|
|
||||||
testing_formulae = args.named.first.split(",")
|
testing_formulae = args.named.first.split(",")
|
||||||
testing_formulae.map! { |name| TestRunnerFormula.new(name) }
|
testing_formulae.map! { |name| TestRunnerFormula.new(Formula[name]) }
|
||||||
.freeze
|
.freeze
|
||||||
deleted_formulae = args.named.second&.split(",")
|
deleted_formulae = args.named.second&.split(",")
|
||||||
|
|
||||||
@ -149,7 +179,12 @@ module Homebrew
|
|||||||
cleanup: linux_cleanup == "true",
|
cleanup: linux_cleanup == "true",
|
||||||
}
|
}
|
||||||
|
|
||||||
with_env(HOMEBREW_SIMULATE_MACOS_ON_LINUX: nil) do
|
if args.dependents?
|
||||||
|
Homebrew::SimulateSystem.os = :linux
|
||||||
|
Homebrew::SimulateSystem.arch = :intel
|
||||||
|
Formulary.clear_cache
|
||||||
|
end
|
||||||
|
|
||||||
if add_runner?(
|
if add_runner?(
|
||||||
testing_formulae,
|
testing_formulae,
|
||||||
reject_platform: :macos,
|
reject_platform: :macos,
|
||||||
@ -159,61 +194,53 @@ module Homebrew
|
|||||||
)
|
)
|
||||||
runners << linux_runner_spec
|
runners << linux_runner_spec
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
# TODO: `HOMEBREW_SIMULATE_MACOS_ON_LINUX` simulates the oldest version of macOS.
|
|
||||||
# Handle formulae that are dependents only on new versions of macOS.
|
|
||||||
with_env(HOMEBREW_SIMULATE_MACOS_ON_LINUX: "1") do
|
|
||||||
if add_runner?(
|
|
||||||
testing_formulae,
|
|
||||||
reject_platform: :linux,
|
|
||||||
deleted_formulae: deleted_formulae,
|
|
||||||
dependents: args.dependents?,
|
|
||||||
)
|
|
||||||
add_intel_runners = add_runner?(
|
|
||||||
testing_formulae,
|
|
||||||
reject_platform: :linux,
|
|
||||||
reject_arch: :arm64,
|
|
||||||
deleted_formulae: deleted_formulae,
|
|
||||||
dependents: args.dependents?,
|
|
||||||
)
|
|
||||||
add_m1_runners = add_runner?(
|
|
||||||
testing_formulae,
|
|
||||||
reject_platform: :linux,
|
|
||||||
reject_arch: :x86_64,
|
|
||||||
deleted_formulae: deleted_formulae,
|
|
||||||
dependents: args.dependents?,
|
|
||||||
)
|
|
||||||
|
|
||||||
github_run_id = ENV.fetch("GITHUB_RUN_ID") { raise "GITHUB_RUN_ID 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_run_attempt = ENV.fetch("GITHUB_RUN_ATTEMPT") { raise "GITHUB_RUN_ATTEMPT is not defined" }
|
||||||
|
ephemeral_suffix = "-#{github_run_id}-#{github_run_attempt}"
|
||||||
|
|
||||||
MacOSVersions::SYMBOLS.each_value do |version|
|
MacOSVersions::SYMBOLS.each do |symbol, version|
|
||||||
macos_version = MacOS::Version.new(version)
|
macos_version = MacOS::Version.new(version)
|
||||||
next if macos_version.outdated_release? || macos_version.prerelease?
|
next if macos_version.outdated_release? || macos_version.prerelease?
|
||||||
|
|
||||||
unless add_runner?(
|
if args.dependents?
|
||||||
|
Formulary.clear_cache
|
||||||
|
Homebrew::SimulateSystem.os = symbol
|
||||||
|
Homebrew::SimulateSystem.arch = :intel
|
||||||
|
end
|
||||||
|
|
||||||
|
if add_runner?(
|
||||||
testing_formulae,
|
testing_formulae,
|
||||||
reject_platform: :linux,
|
reject_platform: :linux,
|
||||||
|
reject_arch: :arm64,
|
||||||
select_macos_version: macos_version,
|
select_macos_version: macos_version,
|
||||||
deleted_formulae: deleted_formulae,
|
deleted_formulae: deleted_formulae,
|
||||||
dependents: args.dependents?,
|
dependents: args.dependents?,
|
||||||
)
|
)
|
||||||
next # No formulae to test on this macOS version.
|
runners << { runner: "#{version}#{ephemeral_suffix}", cleanup: false }
|
||||||
end
|
end
|
||||||
|
|
||||||
ephemeral_suffix = "-#{github_run_id}-#{github_run_attempt}"
|
if args.dependents?
|
||||||
runners << { runner: "#{macos_version}#{ephemeral_suffix}", cleanup: false } if add_intel_runners
|
Formulary.clear_cache
|
||||||
|
Homebrew::SimulateSystem.os = symbol
|
||||||
|
Homebrew::SimulateSystem.arch = :arm
|
||||||
|
end
|
||||||
|
|
||||||
next unless add_m1_runners
|
next unless add_runner?(
|
||||||
|
testing_formulae,
|
||||||
|
reject_platform: :linux,
|
||||||
|
reject_arch: :x86_64,
|
||||||
|
select_macos_version: macos_version,
|
||||||
|
deleted_formulae: deleted_formulae,
|
||||||
|
dependents: args.dependents?,
|
||||||
|
)
|
||||||
|
|
||||||
|
runner_name = "#{version}-arm64"
|
||||||
# Use bare metal runner when testing dependents on Monterey.
|
# Use bare metal runner when testing dependents on Monterey.
|
||||||
if macos_version >= :ventura || (macos_version >= :monterey && !args.dependents?)
|
if macos_version >= :ventura || (macos_version >= :monterey && !args.dependents?)
|
||||||
runners << { runner: "#{macos_version}-arm64#{ephemeral_suffix}", cleanup: false }
|
runners << { runner: "#{runner_name}#{ephemeral_suffix}", cleanup: false }
|
||||||
elsif macos_version >= :big_sur
|
elsif macos_version >= :big_sur
|
||||||
runners << { runner: "#{macos_version}-arm64", cleanup: true }
|
runners << { runner: runner_name, cleanup: true }
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -230,5 +257,3 @@ module Homebrew
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
require "extend/os/dev-cmd/determine-test-runners"
|
|
||||||
|
@ -1,4 +0,0 @@
|
|||||||
# typed: strict
|
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require "extend/os/linux/dev-cmd/determine-test-runners" if OS.linux?
|
|
@ -1,49 +0,0 @@
|
|||||||
# typed: strict
|
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
class TestRunnerFormula
|
|
||||||
extend T::Sig
|
|
||||||
|
|
||||||
sig { returns(T::Array[TestRunnerFormula]) }
|
|
||||||
def dependents
|
|
||||||
@dependent_hash[ENV["HOMEBREW_SIMULATE_MACOS_ON_LINUX"].present?] ||= with_env(HOMEBREW_STDERR: "1") do
|
|
||||||
Utils.safe_popen_read(
|
|
||||||
HOMEBREW_BREW_FILE, "uses", "--formulae", "--eval-all", "--include-build", "--include-test", name
|
|
||||||
).split("\n").map { |dependent| TestRunnerFormula.new(dependent) }.freeze
|
|
||||||
end
|
|
||||||
|
|
||||||
@dependent_hash.fetch(ENV["HOMEBREW_SIMULATE_MACOS_ON_LINUX"].present?)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
module Homebrew
|
|
||||||
extend T::Sig
|
|
||||||
|
|
||||||
sig {
|
|
||||||
params(
|
|
||||||
testing_formulae: T::Array[TestRunnerFormula],
|
|
||||||
reject_platform: T.nilable(Symbol),
|
|
||||||
reject_arch: T.nilable(Symbol),
|
|
||||||
select_macos_version: T.nilable(MacOS::Version),
|
|
||||||
).returns(T::Boolean)
|
|
||||||
}
|
|
||||||
def self.formulae_have_untested_dependents?(testing_formulae, reject_platform:, reject_arch:, select_macos_version:)
|
|
||||||
testing_formulae.any? do |formula|
|
|
||||||
# If the formula has a platform/arch/macOS version requirement, then its
|
|
||||||
# dependents don't need to be tested if these requirements are not satisfied.
|
|
||||||
next false if reject_platform && formula.send(:"#{reject_platform}_only?")
|
|
||||||
next false if reject_arch && formula.send(:"#{reject_arch}_only?")
|
|
||||||
next false if select_macos_version && !formula.compatible_with?(select_macos_version)
|
|
||||||
|
|
||||||
compatible_dependents = formula.dependents.dup
|
|
||||||
|
|
||||||
compatible_dependents.reject! { |dependent_f| dependent_f.send(:"#{reject_arch}_only?") } if reject_arch
|
|
||||||
compatible_dependents.reject! { |dependent_f| dependent_f.send(:"#{reject_platform}_only?") } if reject_platform
|
|
||||||
if select_macos_version
|
|
||||||
compatible_dependents.select! { |dependent_f| dependent_f.compatible_with?(select_macos_version) }
|
|
||||||
end
|
|
||||||
|
|
||||||
(compatible_dependents - testing_formulae).present?
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
@ -163,13 +163,19 @@ describe "brew determine-test-runners" do
|
|||||||
end
|
end
|
||||||
|
|
||||||
describe "--dependents" do
|
describe "--dependents" do
|
||||||
it "fails on macOS", :integration_test, :needs_macos do
|
it "assignes no runners for formulae with no dependents", :integration_test do
|
||||||
setup_test_formula "testball"
|
setup_test_formula "testball"
|
||||||
|
|
||||||
expect { brew "determine-test-runners", "--dependents", "testball", runner_env.dup }
|
expect do
|
||||||
|
brew "determine-test-runners", "--dependents", "testball",
|
||||||
|
runner_env.merge({ "GITHUB_OUTPUT" => github_output })
|
||||||
|
end
|
||||||
.to not_to_output.to_stdout
|
.to not_to_output.to_stdout
|
||||||
.and output("Error: `--dependents` is supported only on Linux!\n").to_stderr
|
.and not_to_output.to_stderr
|
||||||
.and be_a_failure
|
.and be_a_success
|
||||||
|
|
||||||
|
expect(File.read(github_output)).not_to be_empty
|
||||||
|
expect(get_runners(github_output)).to eq([])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user