Hack a first working version of upgrade
This commit is contained in:
parent
4c44266aa5
commit
55727b7895
@ -21,6 +21,7 @@ require "hbc/cli/reinstall"
|
||||
require "hbc/cli/search"
|
||||
require "hbc/cli/style"
|
||||
require "hbc/cli/uninstall"
|
||||
require "hbc/cli/upgrade"
|
||||
require "hbc/cli/--version"
|
||||
require "hbc/cli/zap"
|
||||
|
||||
|
||||
65
Library/Homebrew/cask/lib/hbc/cli/upgrade.rb
Normal file
65
Library/Homebrew/cask/lib/hbc/cli/upgrade.rb
Normal file
@ -0,0 +1,65 @@
|
||||
module Hbc
|
||||
class CLI
|
||||
class Upgrade < AbstractCommand
|
||||
option "--greedy", :greedy, false
|
||||
option "--quiet", :quiet, false
|
||||
option "--force", :force, false
|
||||
option "--force-update", :force_update, false
|
||||
option "--skip-cask-deps", :skip_cask_deps, false
|
||||
|
||||
def initialize(*)
|
||||
super
|
||||
self.verbose = ($stdout.tty? || verbose?) && !quiet?
|
||||
end
|
||||
|
||||
def run
|
||||
outdated_casks = casks(alternative: -> { Hbc.installed }).find_all { |cask| cask.outdated?(greedy?) }
|
||||
|
||||
if outdated_casks.empty?
|
||||
oh1 "No packages to upgrade"
|
||||
else
|
||||
oh1 "Upgrading #{Formatter.pluralize(outdated_casks.length, "outdated package")}, with result:"
|
||||
puts outdated_casks.map { |f| "#{f.full_name} #{f.version}" } * ", "
|
||||
end
|
||||
|
||||
outdated_casks.each do |old_cask|
|
||||
odebug "Uninstalling Cask #{old_cask}"
|
||||
|
||||
raise CaskNotInstalledError, old_cask unless old_cask.installed? || force?
|
||||
|
||||
unless old_cask.installed_caskfile.nil?
|
||||
# use the same cask file that was used for installation, if possible
|
||||
old_cask = CaskLoader.load(old_cask.installed_caskfile) if old_cask.installed_caskfile.exist?
|
||||
end
|
||||
|
||||
old_cask_installer = Installer.new(old_cask, binaries: binaries?, verbose: verbose?, force: force?, upgrade: true)
|
||||
|
||||
old_cask_installer.uninstall
|
||||
|
||||
begin
|
||||
odebug "Installing new version of Cask #{old_cask}"
|
||||
|
||||
new_cask = CaskLoader.load(old_cask.to_s)
|
||||
|
||||
Installer.new(new_cask, binaries: binaries?,
|
||||
verbose: verbose?,
|
||||
force: force?,
|
||||
skip_cask_deps: skip_cask_deps?,
|
||||
require_sha: require_sha?,
|
||||
upgrade: true).install
|
||||
|
||||
old_cask_installer.finalize_upgrade
|
||||
rescue CaskUnavailableError => e
|
||||
opoo e.message
|
||||
rescue CaskAlreadyInstalledError => e
|
||||
opoo e.message
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
def self.help
|
||||
"upgrades all outdated casks"
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -19,7 +19,7 @@ module Hbc
|
||||
|
||||
PERSISTENT_METADATA_SUBDIRS = ["gpg"].freeze
|
||||
|
||||
def initialize(cask, command: SystemCommand, force: false, skip_cask_deps: false, binaries: true, verbose: false, require_sha: false)
|
||||
def initialize(cask, command: SystemCommand, force: false, skip_cask_deps: false, binaries: true, verbose: false, require_sha: false, upgrade: false)
|
||||
@cask = cask
|
||||
@command = command
|
||||
@force = force
|
||||
@ -28,6 +28,7 @@ module Hbc
|
||||
@verbose = verbose
|
||||
@require_sha = require_sha
|
||||
@reinstall = false
|
||||
@upgrade = upgrade
|
||||
end
|
||||
|
||||
attr_predicate :binaries?, :force?, :skip_cask_deps?, :require_sha?, :verbose?
|
||||
@ -82,7 +83,7 @@ module Hbc
|
||||
def install
|
||||
odebug "Hbc::Installer#install"
|
||||
|
||||
if @cask.installed? && !force? && !@reinstall
|
||||
if @cask.installed? && !force? && !@reinstall && !@upgrade
|
||||
raise CaskAlreadyInstalledError, @cask
|
||||
end
|
||||
|
||||
@ -129,7 +130,7 @@ module Hbc
|
||||
installed_cask = installed_caskfile.exist? ? CaskLoader.load(installed_caskfile) : @cask
|
||||
|
||||
# Always force uninstallation, ignore method parameter
|
||||
Installer.new(installed_cask, binaries: binaries?, verbose: verbose?, force: true).uninstall
|
||||
Installer.new(installed_cask, binaries: binaries?, verbose: verbose?, force: true, upgrade: @upgrade).uninstall
|
||||
end
|
||||
|
||||
def summary
|
||||
@ -368,6 +369,15 @@ module Hbc
|
||||
oh1 "Uninstalling Cask #{@cask}"
|
||||
disable_accessibility_access
|
||||
uninstall_artifacts
|
||||
return if @upgrade
|
||||
|
||||
purge_versioned_files
|
||||
purge_caskroom_path if force?
|
||||
end
|
||||
|
||||
def finalize_upgrade
|
||||
return unless @upgrade
|
||||
|
||||
purge_versioned_files
|
||||
purge_caskroom_path if force?
|
||||
end
|
||||
|
||||
78
Library/Homebrew/test/cask/cli/upgrade_spec.rb
Normal file
78
Library/Homebrew/test/cask/cli/upgrade_spec.rb
Normal file
@ -0,0 +1,78 @@
|
||||
require_relative "shared_examples/invalid_option"
|
||||
|
||||
describe Hbc::CLI::Upgrade, :cask do
|
||||
let(:installed) do
|
||||
[
|
||||
Hbc::CaskLoader.load(cask_path("outdated/local-caffeine")),
|
||||
Hbc::CaskLoader.load(cask_path("outdated/local-transmission")),
|
||||
Hbc::CaskLoader.load(cask_path("outdated/auto-updates")),
|
||||
]
|
||||
end
|
||||
|
||||
it_behaves_like "a command that handles invalid options"
|
||||
|
||||
before(:example) do
|
||||
installed.each { |cask| InstallHelper.install_with_caskfile(cask) }
|
||||
|
||||
allow_any_instance_of(described_class).to receive(:verbose?).and_return(true)
|
||||
end
|
||||
|
||||
describe 'without --greedy it ignores the Casks with "version latest" or "auto_updates true"' do
|
||||
it "updates all the installed Casks when no token is provided" do
|
||||
described_class.run
|
||||
|
||||
expect(Hbc::CaskLoader.load("local-caffeine")).to be_installed
|
||||
expect(Hbc.appdir.join("Caffeine.app")).to be_a_directory
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.3")
|
||||
|
||||
expect(Hbc::CaskLoader.load("local-transmission")).to be_installed
|
||||
expect(Hbc.appdir.join("Transmission.app")).to be_a_directory
|
||||
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.61")
|
||||
end
|
||||
|
||||
it "updates only the Casks specified in the command line" do
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.2")
|
||||
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
||||
|
||||
described_class.run("local-caffeine")
|
||||
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.3")
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to_not include("1.2.2")
|
||||
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
||||
end
|
||||
|
||||
it 'ignores "auto_updates" and "latest" Casks even when their tokens are provided in the command line' do
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.2")
|
||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||
|
||||
described_class.run("local-caffeine", "auto-updates", "version-latest-string")
|
||||
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.3")
|
||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||
end
|
||||
end
|
||||
|
||||
describe "with --greedy it checks additional Casks" do
|
||||
it 'includes the Casks with "auto_updates true" or "version latest" with --greedy' do
|
||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.2")
|
||||
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
||||
|
||||
described_class.run("--greedy")
|
||||
|
||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
||||
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.3")
|
||||
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.61")
|
||||
end
|
||||
|
||||
it 'does not include the Casks with "auto_updates true" when the version did not change' do
|
||||
cask = Hbc::CaskLoader.load(cask_path("auto-updates"))
|
||||
InstallHelper.install_with_caskfile(cask)
|
||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
||||
|
||||
described_class.run("auto-updates", "--greedy")
|
||||
|
||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
||||
end
|
||||
end
|
||||
end
|
||||
Loading…
x
Reference in New Issue
Block a user