brew/Library/Homebrew/test/requirement_spec.rb

285 lines
6.5 KiB
Ruby
Raw Normal View History

2017-02-12 17:26:34 +01:00
require "extend/ENV"
require "requirement"
RSpec::Matchers.alias_matcher :have_a_default_formula, :be_a_default_formula
RSpec::Matchers.alias_matcher :be_a_build_requirement, :be_a_build
describe Requirement do
subject { klass.new }
let(:klass) { Class.new(described_class) }
describe "#tags" do
subject { described_class.new(tags) }
context "single tag" do
let(:tags) { ["bar"] }
its(:tags) { are_expected.to eq(tags) }
end
context "multiple tags" do
let(:tags) { ["bar", "baz"] }
its(:tags) { are_expected.to eq(tags) }
end
context "symbol tags" do
let(:tags) { [:build] }
its(:tags) { are_expected.to eq(tags) }
end
context "symbol and string tags" do
let(:tags) { [:build, "bar"] }
its(:tags) { are_expected.to eq(tags) }
end
end
describe "#fatal?" do
context "#fatal true is specified" do
let(:klass) do
Class.new(described_class) do
fatal true
end
end
it { is_expected.to be_fatal }
end
context "#fatal is ommitted" do
it { is_expected.not_to be_fatal }
end
end
describe "#satisfied?" do
context "#satisfy with block and build_env returns true" do
let(:klass) do
Class.new(described_class) do
satisfy(build_env: false) do
true
end
end
end
it { is_expected.to be_satisfied }
end
context "#satisfy with block and build_env returns false" do
let(:klass) do
Class.new(described_class) do
satisfy(build_env: false) do
false
end
end
end
it { is_expected.not_to be_satisfied }
end
context "#satisfy returns true" do
let(:klass) do
Class.new(described_class) do
satisfy true
end
end
it { is_expected.to be_satisfied }
end
context "#satisfy returns false" do
let(:klass) do
Class.new(described_class) do
satisfy false
end
end
it { is_expected.not_to be_satisfied }
end
context "#satisfy with block returning true and without :build_env" do
let(:klass) do
Class.new(described_class) do
satisfy do
true
end
end
end
it "sets up build environment" do
expect(ENV).to receive(:with_build_environment).and_call_original
subject.satisfied?
end
end
context "#satisfy with block returning true and :build_env set to false" do
let(:klass) do
Class.new(described_class) do
satisfy(build_env: false) do
true
end
end
end
it "skips setting up build environment" do
expect(ENV).not_to receive(:with_build_environment)
subject.satisfied?
end
end
context "#satisfy with block returning path and without :build_env" do
let(:klass) do
Class.new(described_class) do
satisfy do
Pathname.new("/foo/bar/baz")
end
end
end
it "infers path from #satisfy result" do
expect(ENV).to receive(:append_path).with("PATH", Pathname.new("/foo/bar"))
subject.satisfied?
subject.modify_build_environment
end
end
end
describe "#build?" do
context ":build tag is specified" do
subject { described_class.new([:build]) }
2017-02-12 17:26:34 +01:00
it { is_expected.to be_a_build_requirement }
end
context "#build omitted" do
2017-02-12 17:26:34 +01:00
it { is_expected.not_to be_a_build_requirement }
end
end
describe "#name and #option_names" do
let(:const) { :FooRequirement }
let(:klass) { self.class.const_get(const) }
before(:each) do
self.class.const_set(const, Class.new(described_class))
end
after(:each) do
self.class.send(:remove_const, const)
end
its(:name) { is_expected.to eq("foo") }
its(:option_names) { are_expected.to eq(["foo"]) }
end
describe "#default_formula?" do
context "#default_formula specified" do
let(:klass) do
Class.new(described_class) do
default_formula "foo"
end
end
it { is_expected.to have_a_default_formula }
end
context "#default_formula ommitted" do
it { is_expected.not_to have_a_default_formula }
end
end
describe "#to_dependency" do
let(:klass) do
Class.new(described_class) do
default_formula "foo"
end
end
it "returns a Dependency for its default Formula" do
expect(subject.to_dependency).to eq(Dependency.new("foo"))
end
context "#modify_build_environment" do
context "with error" do
let(:klass) do
Class.new(described_class) do
class ModifyBuildEnvironmentError < StandardError; end
default_formula "foo"
satisfy do
true
end
env do
raise ModifyBuildEnvironmentError
end
end
end
it "raises an error" do
expect {
subject.to_dependency.modify_build_environment
}.to raise_error(klass.const_get(:ModifyBuildEnvironmentError))
end
end
end
end
describe "#modify_build_environment" do
context "without env proc" do
let(:klass) { Class.new(described_class) }
it "returns nil" do
expect(subject.modify_build_environment).to be nil
end
end
end
describe "#eql? and #==" do
subject { described_class.new }
it "returns true if the names and tags are equal" do
other = described_class.new
expect(subject).to eql(other)
expect(subject).to eq(other)
end
it "returns false if names differ" do
other = described_class.new
allow(other).to receive(:name).and_return("foo")
expect(subject).not_to eql(other)
expect(subject).not_to eq(other)
end
it "returns false if tags differ" do
other = described_class.new([:optional])
expect(subject).not_to eql(other)
expect(subject).not_to eq(other)
end
end
describe "#hash" do
subject { described_class.new }
it "is equal if names and tags are equal" do
other = described_class.new
expect(subject.hash).to eq(other.hash)
end
it "differs if names differ" do
other = described_class.new
allow(other).to receive(:name).and_return("foo")
expect(subject.hash).not_to eq(other.hash)
end
it "differs if tags differ" do
other = described_class.new([:optional])
expect(subject.hash).not_to eq(other.hash)
end
end
end