| 
									
										
										
										
											2017-03-05 19:26:56 +01:00
										 |  |  | describe Hbc::DSL, :cask do | 
					
						
							| 
									
										
										
										
											2017-10-07 15:58:49 +02:00
										 |  |  |   let(:cask) { Hbc::CaskLoader.load(cask_path(token.to_s)) } | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |   let(:token) { "basic-cask" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   context "stanzas" do | 
					
						
							|  |  |  |     it "lets you set url, homepage, and version" do | 
					
						
							|  |  |  |       expect(cask.url.to_s).to eq("http://example.com/TestCask.dmg") | 
					
						
							|  |  |  |       expect(cask.homepage).to eq("http://example.com/") | 
					
						
							|  |  |  |       expect(cask.version.to_s).to eq("1.2.3") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "when a Cask includes an unknown method" do | 
					
						
							|  |  |  |     let(:attempt_unknown_method) { | 
					
						
							|  |  |  |       lambda do | 
					
						
							|  |  |  |         Hbc::Cask.new("unexpected-method-cask") do | 
					
						
							|  |  |  |           future_feature :not_yet_on_your_machine | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "prints a warning that it has encountered an unexpected method" do | 
					
						
							| 
									
										
										
										
											2017-10-15 02:28:32 +02:00
										 |  |  |       expected = Regexp.compile(<<~EOS.lines.map(&:chomp).join("")) | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |         (?m) | 
					
						
							|  |  |  |         Warning: | 
					
						
							|  |  |  |         .* | 
					
						
							|  |  |  |         Unexpected method 'future_feature' called on Cask unexpected-method-cask\\. | 
					
						
							|  |  |  |         .* | 
					
						
							|  |  |  |         https://github.com/caskroom/homebrew-cask#reporting-bugs | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect { | 
					
						
							|  |  |  |         expect(attempt_unknown_method).not_to output.to_stdout | 
					
						
							|  |  |  |       }.to output(expected).to_stderr | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "will simply warn, not throw an exception" do | 
					
						
							|  |  |  |       expect { | 
					
						
							| 
									
										
										
										
											2017-07-29 19:55:05 +02:00
										 |  |  |         attempt_unknown_method.call | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       }.not_to raise_error | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "header line" do | 
					
						
							|  |  |  |     context "when invalid" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-header-format" } | 
					
						
							|  |  |  |       it "raises an error" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(SyntaxError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "when token does not match the file name" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-header-token-mismatch" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "raises an error" do | 
					
						
							|  |  |  |         expect { | 
					
						
							|  |  |  |           cask | 
					
						
							| 
									
										
										
										
											2017-06-11 02:00:59 +02:00
										 |  |  |         }.to raise_error(Hbc::CaskTokenMismatchError, /header line does not match the file name/) | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "when it contains no DSL version" do | 
					
						
							|  |  |  |       let(:token) { "no-dsl-version" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "does not require a DSL version in the header" do | 
					
						
							|  |  |  |         expect(cask.token).to eq("no-dsl-version") | 
					
						
							|  |  |  |         expect(cask.url.to_s).to eq("http://example.com/TestCask.dmg") | 
					
						
							|  |  |  |         expect(cask.homepage).to eq("http://example.com/") | 
					
						
							|  |  |  |         expect(cask.version.to_s).to eq("1.2.3") | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 19:26:56 +01:00
										 |  |  |     context "when it contains a deprecated DSL version", :needs_compat do | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       let(:token) { "with-dsl-version" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "may use deprecated DSL version hash syntax" do | 
					
						
							|  |  |  |         allow(ENV).to receive(:[]).with("HOMEBREW_DEVELOPER").and_return(nil) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-29 19:55:05 +02:00
										 |  |  |         expect(cask.token).to eq("with-dsl-version") | 
					
						
							|  |  |  |         expect(cask.url.to_s).to eq("http://example.com/TestCask.dmg") | 
					
						
							|  |  |  |         expect(cask.homepage).to eq("http://example.com/") | 
					
						
							|  |  |  |         expect(cask.version.to_s).to eq("1.2.3") | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "name stanza" do | 
					
						
							|  |  |  |     it "lets you set the full name via a name stanza" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("name-cask") do | 
					
						
							|  |  |  |         name "Proper Name" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.name).to eq([ | 
					
						
							|  |  |  |                                 "Proper Name", | 
					
						
							|  |  |  |                               ]) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "Accepts an array value to the name stanza" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("array-name-cask") do | 
					
						
							|  |  |  |         name ["Proper Name", "Alternate Name"] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.name).to eq([ | 
					
						
							|  |  |  |                                 "Proper Name", | 
					
						
							|  |  |  |                                 "Alternate Name", | 
					
						
							|  |  |  |                               ]) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "Accepts multiple name stanzas" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("multi-name-cask") do | 
					
						
							|  |  |  |         name "Proper Name" | 
					
						
							|  |  |  |         name "Alternate Name" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.name).to eq([ | 
					
						
							|  |  |  |                                 "Proper Name", | 
					
						
							|  |  |  |                                 "Alternate Name", | 
					
						
							|  |  |  |                               ]) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "sha256 stanza" do | 
					
						
							|  |  |  |     it "lets you set checksum via sha256" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("checksum-cask") do | 
					
						
							|  |  |  |         sha256 "imasha2" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.sha256).to eq("imasha2") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "language stanza" do | 
					
						
							|  |  |  |     it "allows multilingual casks" do | 
					
						
							|  |  |  |       cask = lambda do | 
					
						
							|  |  |  |         Hbc::Cask.new("cask-with-apps") do | 
					
						
							|  |  |  |           language "zh" do | 
					
						
							|  |  |  |             sha256 "abc123" | 
					
						
							|  |  |  |             "zh-CN" | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           language "en-US", default: true do | 
					
						
							|  |  |  |             sha256 "xyz789" | 
					
						
							|  |  |  |             "en-US" | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           url "https://example.org/#{language}.zip" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       allow(MacOS).to receive(:languages).and_return(["zh"]) | 
					
						
							|  |  |  |       expect(cask.call.language).to eq("zh-CN") | 
					
						
							|  |  |  |       expect(cask.call.sha256).to eq("abc123") | 
					
						
							|  |  |  |       expect(cask.call.url.to_s).to eq("https://example.org/zh-CN.zip") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       allow(MacOS).to receive(:languages).and_return(["zh-XX"]) | 
					
						
							|  |  |  |       expect(cask.call.language).to eq("zh-CN") | 
					
						
							|  |  |  |       expect(cask.call.sha256).to eq("abc123") | 
					
						
							|  |  |  |       expect(cask.call.url.to_s).to eq("https://example.org/zh-CN.zip") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       allow(MacOS).to receive(:languages).and_return(["en"]) | 
					
						
							|  |  |  |       expect(cask.call.language).to eq("en-US") | 
					
						
							|  |  |  |       expect(cask.call.sha256).to eq("xyz789") | 
					
						
							|  |  |  |       expect(cask.call.url.to_s).to eq("https://example.org/en-US.zip") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       allow(MacOS).to receive(:languages).and_return(["xx-XX"]) | 
					
						
							|  |  |  |       expect(cask.call.language).to eq("en-US") | 
					
						
							|  |  |  |       expect(cask.call.sha256).to eq("xyz789") | 
					
						
							|  |  |  |       expect(cask.call.url.to_s).to eq("https://example.org/en-US.zip") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       allow(MacOS).to receive(:languages).and_return(["xx-XX", "zh", "en"]) | 
					
						
							|  |  |  |       expect(cask.call.language).to eq("zh-CN") | 
					
						
							|  |  |  |       expect(cask.call.sha256).to eq("abc123") | 
					
						
							|  |  |  |       expect(cask.call.url.to_s).to eq("https://example.org/zh-CN.zip") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       allow(MacOS).to receive(:languages).and_return(["xx-XX", "en-US", "zh"]) | 
					
						
							|  |  |  |       expect(cask.call.language).to eq("en-US") | 
					
						
							|  |  |  |       expect(cask.call.sha256).to eq("xyz789") | 
					
						
							|  |  |  |       expect(cask.call.url.to_s).to eq("https://example.org/en-US.zip") | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2017-09-27 00:17:47 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-02 11:34:50 -07:00
										 |  |  |     it "returns an empty array if no languages are specified" do | 
					
						
							| 
									
										
										
										
											2017-09-27 00:17:47 -07:00
										 |  |  |       cask = lambda do | 
					
						
							|  |  |  |         Hbc::Cask.new("cask-with-apps") do | 
					
						
							|  |  |  |           url "https://example.org/file.zip" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.call.languages).to be_empty | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "returns an array of available languages" do | 
					
						
							|  |  |  |       cask = lambda do | 
					
						
							|  |  |  |         Hbc::Cask.new("cask-with-apps") do | 
					
						
							|  |  |  |           language "zh" do | 
					
						
							|  |  |  |             sha256 "abc123" | 
					
						
							|  |  |  |             "zh-CN" | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           language "en-US", default: true do | 
					
						
							|  |  |  |             sha256 "xyz789" | 
					
						
							|  |  |  |             "en-US" | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           url "https://example.org/file.zip" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.call.languages).to eq(["zh", "en-US"]) | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "app stanza" do | 
					
						
							|  |  |  |     it "allows you to specify app stanzas" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("cask-with-apps") do | 
					
						
							|  |  |  |         app "Foo.app" | 
					
						
							|  |  |  |         app "Bar.app" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |       expect(cask.artifacts.map(&:to_s)).to eq(["Foo.app (App)", "Bar.app (App)"]) | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "allow app stanzas to be empty" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("cask-with-no-apps") | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |       expect(cask.artifacts).to be_empty | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "caveats stanza" do | 
					
						
							|  |  |  |     it "allows caveats to be specified via a method define" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("plain-cask") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.caveats).to be_empty | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("cask-with-caveats") do | 
					
						
							| 
									
										
										
										
											2017-10-15 02:28:32 +02:00
										 |  |  |         def caveats; <<~EOS | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |           When you install this Cask, you probably want to know this. | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.caveats).to eq("When you install this Cask, you probably want to know this.\n") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "pkg stanza" do | 
					
						
							|  |  |  |     it "allows installable pkgs to be specified" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("cask-with-pkgs") do | 
					
						
							|  |  |  |         pkg "Foo.pkg" | 
					
						
							|  |  |  |         pkg "Bar.pkg" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |       expect(cask.artifacts.map(&:to_s)).to eq(["Foo.pkg (Pkg)", "Bar.pkg (Pkg)"]) | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "url stanza" do | 
					
						
							|  |  |  |     let(:token) { "invalid/invalid-two-url" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "prevents defining multiple urls" do | 
					
						
							|  |  |  |       expect { cask }.to raise_error(Hbc::CaskInvalidError, /'url' stanza may only appear once/) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "homepage stanza" do | 
					
						
							|  |  |  |     let(:token) { "invalid/invalid-two-homepage" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "prevents defining multiple homepages" do | 
					
						
							|  |  |  |       expect { cask }.to raise_error(Hbc::CaskInvalidError, /'homepage' stanza may only appear once/) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "version stanza" do | 
					
						
							|  |  |  |     let(:token) { "invalid/invalid-two-version" } | 
					
						
							|  |  |  |     it "prevents defining multiple versions" do | 
					
						
							|  |  |  |       expect { cask }.to raise_error(Hbc::CaskInvalidError, /'version' stanza may only appear once/) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "appcast stanza" do | 
					
						
							|  |  |  |     let(:token) { "with-appcast" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "allows appcasts to be specified" do | 
					
						
							|  |  |  |       expect(cask.appcast.to_s).to match(/^http/) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "when multiple appcasts are defined" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-appcast-multiple" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "raises an error" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError, /'appcast' stanza may only appear once/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "when appcast URL is invalid" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-appcast-url" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "GPG stanza" do | 
					
						
							|  |  |  |     context "valid" do | 
					
						
							|  |  |  |       let(:token) { "with-gpg" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "is allowed to be specified" do | 
					
						
							|  |  |  |         expect(cask.gpg.to_s).to match(/\S/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "with :key_url" do | 
					
						
							|  |  |  |       let(:token) { "with-gpg-key-url" } | 
					
						
							|  |  |  |       it "is allowed to be specified" do | 
					
						
							|  |  |  |         expect(cask.gpg.to_s).to match(/\S/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "specifying mmultiple times" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-multiple-stanzas" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "is not allowed" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError, /'gpg' stanza may only appear once/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "missing GPG key parameters" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-missing-key" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError, /'gpg' stanza must include exactly one/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "conflicting GPG key parameters" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-conflicting-keys" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError, /'gpg' stanza must include exactly one/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid GPG signature URLs" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-signature-url" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid GPG key URLs" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-key-url" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid GPG key IDs" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-key-id" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "GPG parameter is unknown" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-gpg-parameter" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "depends_on stanza" do | 
					
						
							|  |  |  |     let(:token) { "invalid/invalid-depends-on-key" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "refuses to load with an invalid depends_on key" do | 
					
						
							|  |  |  |       expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "depends_on formula" do | 
					
						
							|  |  |  |     context "with one Formula" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-formula" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows depends_on formula to be specified" do | 
					
						
							|  |  |  |         expect(cask.depends_on.formula).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "with multiple Formulae" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-formula-multiple" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows multiple depends_on formula to be specified" do | 
					
						
							|  |  |  |         expect(cask.depends_on.formula).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "depends_on cask" do | 
					
						
							|  |  |  |     context "specifying one" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-cask" } | 
					
						
							|  |  |  |       it "is allowed" do | 
					
						
							|  |  |  |         expect(cask.depends_on.cask).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "specifying multiple" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-cask-multiple" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "is allowed" do | 
					
						
							|  |  |  |         expect(cask.depends_on.cask).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "depends_on macos" do | 
					
						
							|  |  |  |     context "valid" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-macos-string" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows depends_on macos to be specified" do | 
					
						
							|  |  |  |         expect(cask.depends_on.macos).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid depends_on macos value" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-depends-on-macos-bad-release" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "conflicting depends_on macos forms" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-depends-on-macos-conflicting-forms" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "depends_on arch" do | 
					
						
							|  |  |  |     context "valid" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-arch" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "is allowed to be specified" do | 
					
						
							|  |  |  |         expect(cask.depends_on.arch).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid depends_on arch value" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-depends-on-arch-value" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "depends_on x11" do | 
					
						
							|  |  |  |     context "valid" do | 
					
						
							|  |  |  |       let(:token) { "with-depends-on-x11" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "is allowed to be specified" do | 
					
						
							|  |  |  |         expect(cask.depends_on.x11).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid depends_on x11 value" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-depends-on-x11-value" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "conflicts_with stanza" do | 
					
						
							|  |  |  |     context "valid" do | 
					
						
							|  |  |  |       let(:token) { "with-conflicts-with" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows conflicts_with stanza to be specified" do | 
					
						
							|  |  |  |         expect(cask.conflicts_with.formula).not_to be nil | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "invalid conflicts_with key" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-conflicts-with-key" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "refuses to load invalid conflicts_with key" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "installer stanza" do | 
					
						
							|  |  |  |     context "script" do | 
					
						
							|  |  |  |       let(:token) { "with-installer-script" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows installer script to be specified" do | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |         expect(cask.artifacts.to_a[0].path).to eq(Pathname("/usr/bin/true")) | 
					
						
							|  |  |  |         expect(cask.artifacts.to_a[0].args[:args]).to eq(["--flag"]) | 
					
						
							|  |  |  |         expect(cask.artifacts.to_a[1].path).to eq(Pathname("/usr/bin/false")) | 
					
						
							|  |  |  |         expect(cask.artifacts.to_a[1].args[:args]).to eq(["--flag"]) | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "manual" do | 
					
						
							|  |  |  |       let(:token) { "with-installer-manual" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows installer manual to be specified" do | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |         installer = cask.artifacts.first | 
					
						
							| 
									
										
										
										
											2017-04-06 00:33:31 +02:00
										 |  |  |         expect(installer).to be_a(Hbc::Artifact::Installer::ManualInstaller) | 
					
						
							|  |  |  |         expect(installer.path).to eq(cask.staged_path.join("Caffeine.app")) | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "stage_only stanza" do | 
					
						
							|  |  |  |     context "when there is no other activatable artifact" do | 
					
						
							|  |  |  |       let(:token) { "stage-only" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "allows stage_only stanza to be specified" do | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |         expect(cask.artifacts).to contain_exactly a_kind_of Hbc::Artifact::StageOnly | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context "when there is are activatable artifacts" do | 
					
						
							|  |  |  |       let(:token) { "invalid/invalid-stage-only-conflict" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "prevents specifying stage_only" do | 
					
						
							|  |  |  |         expect { cask }.to raise_error(Hbc::CaskInvalidError, /'stage_only' must be the only activatable artifact/) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe "auto_updates stanza" do | 
					
						
							|  |  |  |     let(:token) { "auto-updates" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "allows auto_updates stanza to be specified" do | 
					
						
							|  |  |  |       expect(cask.auto_updates).to be true | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-04 17:08:35 +02:00
										 |  |  |   describe "#appdir" do | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |     context "interpolation of the appdir in stanzas" do | 
					
						
							|  |  |  |       let(:token) { "appdir-interpolation" } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it "is allowed" do | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |         expect(cask.artifacts.first.source).to eq(Hbc.appdir/"some/path") | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "does not include a trailing slash" do | 
					
						
							|  |  |  |       begin | 
					
						
							|  |  |  |         original_appdir = Hbc.appdir | 
					
						
							|  |  |  |         Hbc.appdir = "#{original_appdir}/" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         cask = Hbc::Cask.new("appdir-trailing-slash") do | 
					
						
							|  |  |  |           binary "#{appdir}/some/path" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-04 17:54:52 +02:00
										 |  |  |         expect(cask.artifacts.first.source).to eq(original_appdir/"some/path") | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  |       ensure | 
					
						
							|  |  |  |         Hbc.appdir = original_appdir | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2017-10-04 17:08:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe "#artifacts" do | 
					
						
							|  |  |  |     it "sorts artifacts according to the preferable installation order" do | 
					
						
							|  |  |  |       cask = Hbc::Cask.new("appdir-trailing-slash") do | 
					
						
							|  |  |  |         postflight do | 
					
						
							|  |  |  |           next | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         preflight do | 
					
						
							|  |  |  |           next | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         binary "binary" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         app "App.app" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cask.artifacts.map(&:class).map(&:dsl_key)).to eq [ | 
					
						
							|  |  |  |         :preflight, | 
					
						
							|  |  |  |         :app, | 
					
						
							|  |  |  |         :binary, | 
					
						
							|  |  |  |         :postflight, | 
					
						
							|  |  |  |       ] | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2017-02-08 10:45:25 +01:00
										 |  |  | end |