| 
									
										
										
										
											2020-10-10 14:16:11 +02:00
										 |  |  | # typed: false | 
					
						
							| 
									
										
										
										
											2019-04-19 15:38:03 +09:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  | require "extend/ENV" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | shared_examples EnvActivation do | 
					
						
							|  |  |  |   subject { env.extend(described_class) } | 
					
						
							| 
									
										
										
										
											2018-03-25 13:30:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |   let(:env) { {}.extend(EnvActivation) } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it "supports switching compilers" do | 
					
						
							|  |  |  |     subject.clang | 
					
						
							|  |  |  |     expect(subject["LD"]).to be nil | 
					
						
							|  |  |  |     expect(subject["CC"]).to eq(subject["OBJC"]) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#with_build_environment" do | 
					
						
							|  |  |  |     it "restores the environment" do | 
					
						
							|  |  |  |       before = subject.dup | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-28 02:04:50 +02:00
										 |  |  |       subject.with_build_environment do | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |         subject["foo"] = "bar" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(subject["foo"]).to be nil | 
					
						
							|  |  |  |       expect(subject).to eq(before) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "ensures the environment is restored" do | 
					
						
							|  |  |  |       before = subject.dup | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect { | 
					
						
							| 
									
										
										
										
											2020-07-28 02:04:50 +02:00
										 |  |  |         subject.with_build_environment do | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |           subject["foo"] = "bar" | 
					
						
							|  |  |  |           raise StandardError | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       }.to raise_error(StandardError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(subject["foo"]).to be nil | 
					
						
							|  |  |  |       expect(subject).to eq(before) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "returns the value of the block" do | 
					
						
							| 
									
										
										
										
											2020-07-28 02:04:50 +02:00
										 |  |  |       expect(subject.with_build_environment { 1 }).to eq(1) | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "does not mutate the interface" do | 
					
						
							|  |  |  |       expected = subject.methods | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-28 02:04:50 +02:00
										 |  |  |       subject.with_build_environment do | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |         expect(subject.methods).to eq(expected) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(subject.methods).to eq(expected) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#append" do | 
					
						
							|  |  |  |     it "appends to an existing key" do | 
					
						
							|  |  |  |       subject["foo"] = "bar" | 
					
						
							|  |  |  |       subject.append "foo", "1" | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("bar 1") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "appends to an existing empty key" do | 
					
						
							|  |  |  |       subject["foo"] = "" | 
					
						
							|  |  |  |       subject.append "foo", "1" | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("1") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-19 14:27:29 +10:00
										 |  |  |     it "appends to a non-existent key" do | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |       subject.append "foo", "1" | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("1") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # NOTE: this may be a wrong behavior; we should probably reject objects that | 
					
						
							|  |  |  |     # do not respond to #to_str. For now this documents existing behavior. | 
					
						
							|  |  |  |     it "coerces a value to a string" do | 
					
						
							|  |  |  |       subject.append "foo", 42
 | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("42") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#prepend" do | 
					
						
							|  |  |  |     it "prepends to an existing key" do | 
					
						
							|  |  |  |       subject["foo"] = "bar" | 
					
						
							|  |  |  |       subject.prepend "foo", "1" | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("1 bar") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "prepends to an existing empty key" do | 
					
						
							|  |  |  |       subject["foo"] = "" | 
					
						
							|  |  |  |       subject.prepend "foo", "1" | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("1") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-19 14:27:29 +10:00
										 |  |  |     it "prepends to a non-existent key" do | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |       subject.prepend "foo", "1" | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("1") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # NOTE: this may be a wrong behavior; we should probably reject objects that | 
					
						
							|  |  |  |     # do not respond to #to_str. For now this documents existing behavior. | 
					
						
							|  |  |  |     it "coerces a value to a string" do | 
					
						
							|  |  |  |       subject.prepend "foo", 42
 | 
					
						
							|  |  |  |       expect(subject["foo"]).to eq("42") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#append_path" do | 
					
						
							|  |  |  |     it "appends to a path" do | 
					
						
							|  |  |  |       subject.append_path "FOO", "/usr/bin" | 
					
						
							|  |  |  |       expect(subject["FOO"]).to eq("/usr/bin") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       subject.append_path "FOO", "/bin" | 
					
						
							|  |  |  |       expect(subject["FOO"]).to eq("/usr/bin#{File::PATH_SEPARATOR}/bin") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#prepend_path" do | 
					
						
							|  |  |  |     it "prepends to a path" do | 
					
						
							| 
									
										
										
										
											2017-05-03 13:24:46 -07:00
										 |  |  |       subject.prepend_path "FOO", "/usr/local" | 
					
						
							|  |  |  |       expect(subject["FOO"]).to eq("/usr/local") | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-10 07:28:55 -08:00
										 |  |  |       subject.prepend_path "FOO", "/usr" | 
					
						
							| 
									
										
										
										
											2017-05-03 13:24:46 -07:00
										 |  |  |       expect(subject["FOO"]).to eq("/usr#{File::PATH_SEPARATOR}/usr/local") | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#compiler" do | 
					
						
							|  |  |  |     it "allows switching compilers" do | 
					
						
							| 
									
										
										
										
											2019-01-26 17:13:14 +00:00
										 |  |  |       subject.public_send("gcc-6") | 
					
						
							|  |  |  |       expect(subject.compiler).to eq("gcc-6") | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   example "deparallelize_block_form_restores_makeflags" do | 
					
						
							|  |  |  |     subject["MAKEFLAGS"] = "-j4" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     subject.deparallelize do | 
					
						
							|  |  |  |       expect(subject["MAKEFLAGS"]).to be nil | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(subject["MAKEFLAGS"]).to eq("-j4") | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-03-01 17:48:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-13 22:48:22 +08:00
										 |  |  |   describe "#sensitive_environment" do | 
					
						
							|  |  |  |     it "list sensitive environment" do | 
					
						
							|  |  |  |       subject["SECRET_TOKEN"] = "password" | 
					
						
							|  |  |  |       expect(subject.sensitive_environment).to include("SECRET_TOKEN") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-01 17:48:08 +00:00
										 |  |  |   describe "#clear_sensitive_environment!" do | 
					
						
							|  |  |  |     it "removes sensitive environment variables" do | 
					
						
							|  |  |  |       subject["SECRET_TOKEN"] = "password" | 
					
						
							|  |  |  |       subject.clear_sensitive_environment! | 
					
						
							|  |  |  |       expect(subject).not_to include("SECRET_TOKEN") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "leaves non-sensitive environment variables alone" do | 
					
						
							|  |  |  |       subject["FOO"] = "bar" | 
					
						
							|  |  |  |       subject.clear_sensitive_environment! | 
					
						
							|  |  |  |       expect(subject["FOO"]).to eq "bar" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-07-05 20:15:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe "#compiler_any_clang?" do | 
					
						
							|  |  |  |     it "returns true for llvm_clang" do | 
					
						
							|  |  |  |       expect(subject.compiler_any_clang?(:llvm_clang)).to be true | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2017-02-25 10:09:26 +01:00
										 |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe Stdenv do | 
					
						
							|  |  |  |   include_examples EnvActivation | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe Superenv do | 
					
						
							|  |  |  |   include_examples EnvActivation | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it "initializes deps" do | 
					
						
							|  |  |  |     expect(subject.deps).to eq([]) | 
					
						
							|  |  |  |     expect(subject.keg_only_deps).to eq([]) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "#cxx11" do | 
					
						
							|  |  |  |     it "supports gcc-5" do | 
					
						
							|  |  |  |       subject["HOMEBREW_CC"] = "gcc-5" | 
					
						
							|  |  |  |       subject.cxx11 | 
					
						
							|  |  |  |       expect(subject["HOMEBREW_CCCFG"]).to include("x") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     example "supports gcc-6" do | 
					
						
							|  |  |  |       subject["HOMEBREW_CC"] = "gcc-6" | 
					
						
							|  |  |  |       subject.cxx11 | 
					
						
							|  |  |  |       expect(subject["HOMEBREW_CCCFG"]).to include("x") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "supports clang" do | 
					
						
							|  |  |  |       subject["HOMEBREW_CC"] = "clang" | 
					
						
							|  |  |  |       subject.cxx11 | 
					
						
							|  |  |  |       expect(subject["HOMEBREW_CCCFG"]).to include("x") | 
					
						
							|  |  |  |       expect(subject["HOMEBREW_CCCFG"]).to include("g") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |