diff --git a/Library/Homebrew/cask/lib/hbc/artifact.rb b/Library/Homebrew/cask/lib/hbc/artifact.rb index 8b4babdf62cb8b42c1424ebbbc7119571491005e..b155a125a81795aea2bd68e32b0f9442bfae902b 100644 --- a/Library/Homebrew/cask/lib/hbc/artifact.rb +++ b/Library/Homebrew/cask/lib/hbc/artifact.rb @@ -27,41 +27,39 @@ module Hbc module Artifact # NOTE: order is important here, since we want to extract nested containers # before we handle any other artifacts - def self.artifacts - [ - PreflightBlock, - NestedContainer, - Installer, - App, - Suite, - Artifact, # generic 'artifact' stanza - Colorpicker, - Pkg, - Prefpane, - Qlplugin, - Dictionary, - Font, - Service, - StageOnly, - Binary, - InputMethod, - InternetPlugin, - AudioUnitPlugin, - VstPlugin, - Vst3Plugin, - ScreenSaver, - Uninstall, - PostflightBlock, - Zap, - ] - end + TYPES = [ + PreflightBlock, + NestedContainer, + Installer, + App, + Suite, + Artifact, # generic 'artifact' stanza + Colorpicker, + Pkg, + Prefpane, + Qlplugin, + Dictionary, + Font, + Service, + StageOnly, + Binary, + InputMethod, + InternetPlugin, + AudioUnitPlugin, + VstPlugin, + Vst3Plugin, + ScreenSaver, + Uninstall, + PostflightBlock, + Zap, + ].freeze - def self.for_cask(cask) + def self.for_cask(cask, command: SystemCommand, force: false) odebug "Determining which artifacts are present in Cask #{cask}" - artifacts.select do |artifact| - odebug "Checking for artifact class #{artifact}" - artifact.me?(cask) - end + + TYPES + .select { |klass| klass.me?(cask) } + .map { |klass| klass.new(cask, command: command, force: force) } end end end diff --git a/Library/Homebrew/cask/lib/hbc/cli/list.rb b/Library/Homebrew/cask/lib/hbc/cli/list.rb index 4094b3d38cc6378d9c0fc63d472a66ef97e029a3..e100fbd833ac90cfcaf04c92a8c711b078fe4f8e 100644 --- a/Library/Homebrew/cask/lib/hbc/cli/list.rb +++ b/Library/Homebrew/cask/lib/hbc/cli/list.rb @@ -55,7 +55,7 @@ module Hbc def self.list_artifacts(cask) Artifact.for_cask(cask).each do |artifact| - summary = artifact.new(cask).summary + summary = artifact.summary ohai summary[:english_description], summary[:contents] unless summary.empty? end end diff --git a/Library/Homebrew/cask/lib/hbc/dsl.rb b/Library/Homebrew/cask/lib/hbc/dsl.rb index c62873665c936a28d71896b17381e756f78a6d2e..4707ae76a968f1b8fc0029c9bd92ffea2251d006 100644 --- a/Library/Homebrew/cask/lib/hbc/dsl.rb +++ b/Library/Homebrew/cask/lib/hbc/dsl.rb @@ -270,14 +270,17 @@ module Hbc ORDINARY_ARTIFACT_TYPES.each do |type| define_method(type) do |*args| - if type == :stage_only && args != [true] - raise CaskInvalidError.new(token, "'stage_only' takes a single argument: true") - end - artifacts[type] << args - if artifacts.key?(:stage_only) && artifacts.keys.count > 1 && - !(artifacts.keys & ACTIVATABLE_ARTIFACT_TYPES).empty? - raise CaskInvalidError.new(token, "'stage_only' must be the only activatable artifact") + if type == :stage_only + if args != [true] + raise CaskInvalidError.new(token, "'stage_only' takes a single argument: true") + end + + unless (artifacts.keys & ACTIVATABLE_ARTIFACT_TYPES).empty? + raise CaskInvalidError.new(token, "'stage_only' must be the only activatable artifact") + end end + + artifacts[type].add(args) end end diff --git a/Library/Homebrew/cask/lib/hbc/installer.rb b/Library/Homebrew/cask/lib/hbc/installer.rb index 28f67e5fd0d220e33eba3d3dc0631dfe6fa25778..776a3acd28359707926d84e3323e51abe06154f8 100644 --- a/Library/Homebrew/cask/lib/hbc/installer.rb +++ b/Library/Homebrew/cask/lib/hbc/installer.rb @@ -133,16 +133,14 @@ module Hbc def install_artifacts already_installed_artifacts = [] - options = { command: @command, force: force } odebug "Installing artifacts" - artifacts = Artifact.for_cask(@cask) + artifacts = Artifact.for_cask(@cask, command: @command, force: force) odebug "#{artifacts.length} artifact/s defined", artifacts artifacts.each do |artifact| - artifact = artifact.new(@cask, options) next unless artifact.respond_to?(:install_phase) - odebug "Installing artifact of class #{artifact}" + odebug "Installing artifact of class #{artifact.class}" artifact.install_phase already_installed_artifacts.unshift(artifact) end @@ -150,7 +148,7 @@ module Hbc begin already_installed_artifacts.each do |artifact| next unless artifact.respond_to?(:uninstall_phase) - odebug "Reverting installation of artifact of class #{artifact}" + odebug "Reverting installation of artifact of class #{artifact.class}" artifact.uninstall_phase end ensure @@ -319,13 +317,11 @@ module Hbc def uninstall_artifacts odebug "Un-installing artifacts" - artifacts = Artifact.for_cask(@cask) + artifacts = Artifact.for_cask(@cask, command: @command, force: force) odebug "#{artifacts.length} artifact/s defined", artifacts artifacts.each do |artifact| - options = { command: @command, force: force } - artifact = artifact.new(@cask, options) next unless artifact.respond_to?(:uninstall_phase) - odebug "Un-installing artifact of class #{artifact}" + odebug "Un-installing artifact of class #{artifact.class}" artifact.uninstall_phase end end diff --git a/Library/Homebrew/cask/test/cask/installer_test.rb b/Library/Homebrew/cask/test/cask/installer_test.rb index b26c288478da82328c54e4af140621e04ccb1ad4..17629dce2eeedb9d40be10b429e12f262c73debb 100644 --- a/Library/Homebrew/cask/test/cask/installer_test.rb +++ b/Library/Homebrew/cask/test/cask/installer_test.rb @@ -13,10 +13,8 @@ describe Hbc::Installer do Hbc::Installer.new(caffeine).install end - dest_path = Hbc.caskroom.join("local-caffeine", caffeine.version) - dest_path.must_be :directory? - application = Hbc.appdir.join("Caffeine.app") - application.must_be :directory? + expect(Hbc.caskroom.join("local-caffeine", caffeine.version)).must_be :directory? + expect(Hbc.appdir.join("Caffeine.app")).must_be :directory? end it "works with dmg-based Casks" do @@ -26,10 +24,8 @@ describe Hbc::Installer do Hbc::Installer.new(asset).install end - dest_path = Hbc.caskroom.join("container-dmg", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container") - file.must_be :file? + expect(Hbc.caskroom.join("container-dmg", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with tar-gz-based Casks" do @@ -39,10 +35,8 @@ describe Hbc::Installer do Hbc::Installer.new(asset).install end - dest_path = Hbc.caskroom.join("container-tar-gz", asset.version) - dest_path.must_be :directory? - application = Hbc.appdir.join("container") - application.must_be :file? + expect(Hbc.caskroom.join("container-tar-gz", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with cab-based Casks" do @@ -55,10 +49,8 @@ describe Hbc::Installer do end end - dest_path = Hbc.caskroom.join("container-cab", asset.version) - dest_path.must_be :directory? - application = Hbc.appdir.join("container") - application.must_be :file? + expect(Hbc.caskroom.join("container-cab", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with Adobe AIR-based Casks" do @@ -69,10 +61,8 @@ describe Hbc::Installer do Hbc::Installer.new(asset).install end - dest_path = Hbc.caskroom.join("container-air", asset.version) - dest_path.must_be :directory? - application = Hbc.appdir.join("container.app") - application.must_be :directory? + expect(Hbc.caskroom.join("container-air", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container.app")).must_be :directory? end it "works with 7z-based Casks" do @@ -85,10 +75,8 @@ describe Hbc::Installer do end end - dest_path = Hbc.caskroom.join("container-7z", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container") - file.must_be :file? + expect(Hbc.caskroom.join("container-7z", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with xar-based Casks" do @@ -98,10 +86,8 @@ describe Hbc::Installer do Hbc::Installer.new(asset).install end - dest_path = Hbc.caskroom.join("container-xar", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container") - file.must_be :file? + expect(Hbc.caskroom.join("container-xar", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with Stuffit-based Casks" do @@ -114,10 +100,8 @@ describe Hbc::Installer do end end - dest_path = Hbc.caskroom.join("container-sit", asset.version) - dest_path.must_be :directory? - application = Hbc.appdir.join("container") - application.must_be :file? + expect(Hbc.caskroom.join("container-sit", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with RAR-based Casks" do @@ -130,10 +114,8 @@ describe Hbc::Installer do end end - dest_path = Hbc.caskroom.join("container-rar", asset.version) - dest_path.must_be :directory? - application = Hbc.appdir.join("container") - application.must_be :file? + expect(Hbc.caskroom.join("container-rar", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with pure bzip2-based Casks" do @@ -143,10 +125,8 @@ describe Hbc::Installer do Hbc::Installer.new(asset).install end - dest_path = Hbc.caskroom.join("container-bzip2", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container-bzip2--#{asset.version}") - file.must_be :file? + expect(Hbc.caskroom.join("container-bzip2", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container-bzip2--#{asset.version}")).must_be :file? end it "works with pure gzip-based Casks" do @@ -156,10 +136,8 @@ describe Hbc::Installer do Hbc::Installer.new(asset).install end - dest_path = Hbc.caskroom.join("container-gzip", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container") - file.must_be :file? + expect(Hbc.caskroom.join("container-gzip", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container")).must_be :file? end it "works with pure xz-based Casks" do @@ -172,10 +150,8 @@ describe Hbc::Installer do end end - dest_path = Hbc.caskroom.join("container-xz", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container-xz--#{asset.version}") - file.must_be :file? + expect(Hbc.caskroom.join("container-xz", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container-xz--#{asset.version}")).must_be :file? end it "works with lzma-based Casks" do @@ -188,15 +164,13 @@ describe Hbc::Installer do end end - dest_path = Hbc.caskroom.join("container-lzma", asset.version) - dest_path.must_be :directory? - file = Hbc.appdir.join("container-lzma--#{asset.version}") - file.must_be :file? + expect(Hbc.caskroom.join("container-lzma", asset.version)).must_be :directory? + expect(Hbc.appdir.join("container-lzma--#{asset.version}")).must_be :file? end it "blows up on a bad checksum" do bad_checksum = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/bad-checksum.rb") - lambda { + expect { shutup do Hbc::Installer.new(bad_checksum).install end @@ -205,7 +179,7 @@ describe Hbc::Installer do it "blows up on a missing checksum" do missing_checksum = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/missing-checksum.rb") - lambda { + expect { shutup do Hbc::Installer.new(missing_checksum).install end @@ -219,12 +193,12 @@ describe Hbc::Installer do Hbc::Installer.new(no_checksum).install end - no_checksum.must_be :installed? + expect(no_checksum).must_be :installed? end it "fails to install if sha256 :no_check is used with --require-sha" do no_checksum = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/no-checksum.rb") - lambda { + expect { Hbc::Installer.new(no_checksum, require_sha: true).install }.must_raise(Hbc::CaskNoShasumError) end @@ -236,23 +210,27 @@ describe Hbc::Installer do Hbc::Installer.new(no_checksum, require_sha: true, force: true).install end - no_checksum.must_be :installed? + expect(no_checksum).must_be :installed? end it "prints caveats if they're present" do with_caveats = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/with-caveats.rb") - lambda { + + expect { Hbc::Installer.new(with_caveats).install }.must_output(/Here are some things you might want to know/) - with_caveats.must_be :installed? + + expect(with_caveats).must_be :installed? end it "prints installer :manual instructions when present" do with_installer_manual = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/with-installer-manual.rb") - lambda { + + expect { Hbc::Installer.new(with_installer_manual).install }.must_output(/To complete the installation of Cask with-installer-manual, you must also\nrun the installer at\n\n '#{with_installer_manual.staged_path.join('Caffeine.app')}'/) - with_installer_manual.must_be :installed? + + expect(with_installer_manual).must_be :installed? end it "does not extract __MACOSX directories from zips" do @@ -262,54 +240,60 @@ describe Hbc::Installer do Hbc::Installer.new(with_macosx_dir).install end - with_macosx_dir.staged_path.join("__MACOSX").wont_be :directory? + expect(with_macosx_dir.staged_path.join("__MACOSX")).wont_be :directory? end it "installer method raises an exception when already-installed Casks which auto-update are attempted" do - auto_updates = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/auto-updates.rb") - auto_updates.installed?.must_equal false - installer = Hbc::Installer.new(auto_updates) + with_auto_updates = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/auto-updates.rb") + + expect(with_auto_updates).wont_be :installed? + + installer = Hbc::Installer.new(with_auto_updates) shutup do installer.install end - lambda { + expect { installer.install }.must_raise(Hbc::CaskAlreadyInstalledAutoUpdatesError) end it "allows already-installed Casks which auto-update to be installed if force is provided" do - auto_updates = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/auto-updates.rb") - auto_updates.installed?.must_equal false + with_auto_updates = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/auto-updates.rb") + + expect(with_auto_updates).wont_be :installed? shutup do - Hbc::Installer.new(auto_updates).install + Hbc::Installer.new(with_auto_updates).install end shutup do - Hbc::Installer.new(auto_updates, force: true).install + Hbc::Installer.new(with_auto_updates, force: true).install end # wont_raise end # unlike the CLI, the internal interface throws exception on double-install it "installer method raises an exception when already-installed Casks are attempted" do transmission = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/local-transmission.rb") - transmission.installed?.must_equal false + + expect(transmission).wont_be :installed? + installer = Hbc::Installer.new(transmission) shutup do installer.install end - lambda { + expect { installer.install }.must_raise(Hbc::CaskAlreadyInstalledError) end it "allows already-installed Casks to be installed if force is provided" do transmission = Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/local-transmission.rb") - transmission.installed?.must_equal false + + expect(transmission).wont_be :installed? shutup do Hbc::Installer.new(transmission).install @@ -327,9 +311,7 @@ describe Hbc::Installer do Hbc::Installer.new(naked_pkg).install end - dest_path = Hbc.caskroom.join("container-pkg", naked_pkg.version) - pkg = dest_path.join("container.pkg") - pkg.must_be :file? + expect(Hbc.caskroom.join("container-pkg", naked_pkg.version, "container.pkg")).must_be :file? end it "works properly with an overridden container :type" do @@ -339,9 +321,7 @@ describe Hbc::Installer do Hbc::Installer.new(naked_executable).install end - dest_path = Hbc.caskroom.join("naked-executable", naked_executable.version) - executable = dest_path.join("naked_executable") - executable.must_be :file? + expect(Hbc.caskroom.join("naked-executable", naked_executable.version, "naked_executable")).must_be :file? end it "works fine with a nested container" do @@ -351,8 +331,7 @@ describe Hbc::Installer do Hbc::Installer.new(nested_app).install end - dest_path = Hbc.appdir.join("MyNestedApp.app") - dest_path.must_be :directory? + expect(Hbc.appdir.join("MyNestedApp.app")).must_be :directory? end it "generates and finds a timestamped metadata directory for an installed Cask" do @@ -363,8 +342,8 @@ describe Hbc::Installer do end m_path = caffeine.metadata_path(:now, true) - caffeine.metadata_path(:now, false).must_equal(m_path) - caffeine.metadata_path(:latest).must_equal(m_path) + expect(caffeine.metadata_path(:now, false)).must_equal(m_path) + expect(caffeine.metadata_path(:latest)).must_equal(m_path) end it "generates and finds a metadata subdirectory for an installed Cask" do @@ -376,8 +355,8 @@ describe Hbc::Installer do subdir_name = "Casks" m_subdir = caffeine.metadata_subdir(subdir_name, :now, true) - caffeine.metadata_subdir(subdir_name, :now, false).must_equal(m_subdir) - caffeine.metadata_subdir(subdir_name, :latest).must_equal(m_subdir) + expect(caffeine.metadata_subdir(subdir_name, :now, false)).must_equal(m_subdir) + expect(caffeine.metadata_subdir(subdir_name, :latest)).must_equal(m_subdir) end end @@ -391,9 +370,9 @@ describe Hbc::Installer do installer.uninstall end - Hbc.caskroom.join("local-caffeine", caffeine.version, "Caffeine.app").wont_be :directory? - Hbc.caskroom.join("local-caffeine", caffeine.version).wont_be :directory? - Hbc.caskroom.join("local-caffeine").wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine", caffeine.version, "Caffeine.app")).wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine", caffeine.version)).wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine")).wont_be :directory? end it "uninstalls all versions if force is set" do @@ -404,19 +383,19 @@ describe Hbc::Installer do Hbc::Installer.new(caffeine).install end - Hbc.caskroom.join("local-caffeine", caffeine.version).must_be :directory? - Hbc.caskroom.join("local-caffeine", mutated_version).wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine", caffeine.version)).must_be :directory? + expect(Hbc.caskroom.join("local-caffeine", mutated_version)).wont_be :directory? FileUtils.mv(Hbc.caskroom.join("local-caffeine", caffeine.version), Hbc.caskroom.join("local-caffeine", mutated_version)) - Hbc.caskroom.join("local-caffeine", caffeine.version).wont_be :directory? - Hbc.caskroom.join("local-caffeine", mutated_version).must_be :directory? + expect(Hbc.caskroom.join("local-caffeine", caffeine.version)).wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine", mutated_version)).must_be :directory? shutup do Hbc::Installer.new(caffeine, force: true).uninstall end - Hbc.caskroom.join("local-caffeine", caffeine.version).wont_be :directory? - Hbc.caskroom.join("local-caffeine", mutated_version).wont_be :directory? - Hbc.caskroom.join("local-caffeine").wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine", caffeine.version)).wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine", mutated_version)).wont_be :directory? + expect(Hbc.caskroom.join("local-caffeine")).wont_be :directory? end end end