| 
									
										
										
										
											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 | 
					
						
							| 
									
										
										
										
											2017-04-22 16:28:07 +01:00
										 |  |  |     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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-22 16:28:07 +01:00
										 |  |  |     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 |