brew/Library/Homebrew/test/cli/named_args_spec.rb

124 lines
3.2 KiB
Ruby
Raw Normal View History

2020-08-14 13:48:03 -04:00
# frozen_string_literal: true
require "cli/named_args"
describe Homebrew::CLI::NamedArgs do
let(:foo) do
formula "foo" do
url "https://brew.sh"
version "1.0"
end
end
let(:bar) do
formula "bar" do
url "https://brew.sh"
version "1.0"
end
end
let(:baz) do
Cask::CaskLoader.load(+<<~RUBY)
cask "baz" do
version "1.0"
end
RUBY
end
describe "#to_formulae" do
it "returns formulae" do
stub_formula_loader foo, call_original: true
2020-08-14 13:48:03 -04:00
stub_formula_loader bar
expect(described_class.new("foo", "bar").to_formulae).to eq [foo, bar]
end
it "raises an error when a Formula is unavailable" do
expect { described_class.new("mxcl").to_formulae }.to raise_error FormulaUnavailableError
end
it "returns an empty array when there are no Formulae" do
expect(described_class.new.to_formulae).to be_empty
end
2020-08-14 13:48:03 -04:00
end
describe "#to_formulae_and_casks" do
it "returns formulae and casks" do
stub_formula_loader foo, call_original: true
stub_cask_loader baz, call_original: true
2020-08-14 13:48:03 -04:00
expect(described_class.new("foo", "baz").to_formulae_and_casks).to eq [foo, baz]
end
end
describe "#to_resolved_formulae" do
it "returns resolved formulae" do
allow(Formulary).to receive(:resolve).and_return(foo, bar)
expect(described_class.new("foo", "bar").to_resolved_formulae).to eq [foo, bar]
end
end
describe "#to_resolved_formulae_to_casks" do
it "returns resolved formulae, as well as casks" do
allow(Formulary).to receive(:resolve).and_call_original
allow(Formulary).to receive(:resolve).with("foo", any_args).and_return foo
stub_cask_loader baz, call_original: true
2020-08-14 13:48:03 -04:00
resolved_formulae, casks = described_class.new("foo", "baz").to_resolved_formulae_to_casks
expect(resolved_formulae).to eq [foo]
expect(casks).to eq [baz]
end
end
describe "#to_casks" do
it "returns casks" do
stub_cask_loader baz
expect(described_class.new("baz").to_casks).to eq [baz]
end
end
describe "#to_kegs" do
before do
(HOMEBREW_CELLAR/"foo/1.0").mkpath
(HOMEBREW_CELLAR/"bar/1.0").mkpath
end
2020-08-14 13:48:03 -04:00
it "resolves kegs with #resolve_kegs" do
expect(described_class.new("foo", "bar").to_kegs.map(&:name)).to eq ["foo", "bar"]
end
it "when there are no matching kegs returns an array of Kegs" do
expect(described_class.new.to_kegs).to be_empty
2020-08-14 13:48:03 -04:00
end
end
describe "#to_kegs_to_casks" do
before do
(HOMEBREW_CELLAR/"foo/1.0").mkpath
end
2020-08-14 13:48:03 -04:00
it "returns kegs, as well as casks" do
stub_cask_loader baz, call_original: true
2020-08-14 13:48:03 -04:00
kegs, casks = described_class.new("foo", "baz").to_kegs_to_casks
2020-08-14 13:48:03 -04:00
expect(kegs.map(&:name)).to eq ["foo"]
2020-08-14 13:48:03 -04:00
expect(casks).to eq [baz]
end
end
describe "#homebrew_tap_cask_names" do
it "returns an array of casks from homebrew-cask" do
expect(described_class.new("foo", "homebrew/cask/local-caffeine").homebrew_tap_cask_names)
.to eq ["homebrew/cask/local-caffeine"]
end
it "returns an empty array when there are no matching casks" do
expect(described_class.new("foo").homebrew_tap_cask_names).to be_empty
end
end
2020-08-14 13:48:03 -04:00
end