Fix upgrade tests and some upgrade? leftovers
This commit is contained in:
parent
94d266e2d6
commit
522a229dbb
@ -426,7 +426,7 @@ module Hbc
|
|||||||
end
|
end
|
||||||
|
|
||||||
def purge_versioned_files(upgrade: false)
|
def purge_versioned_files(upgrade: false)
|
||||||
ohai "Purging files for version #{@cask.version} of Cask #{@cask}" unless upgrade?
|
odebug "Purging files for version #{@cask.version} of Cask #{@cask}" unless upgrade?
|
||||||
|
|
||||||
# versioned staged distribution
|
# versioned staged distribution
|
||||||
gain_permissions_remove(@cask.staged_path) if !@cask.staged_path.nil? && @cask.staged_path.exist?
|
gain_permissions_remove(@cask.staged_path) if !@cask.staged_path.nil? && @cask.staged_path.exist?
|
||||||
@ -441,10 +441,10 @@ module Hbc
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
@cask.metadata_versioned_path.rmdir_if_possible
|
@cask.metadata_versioned_path.rmdir_if_possible
|
||||||
@cask.metadata_master_container_path.rmdir_if_possible unless upgrade
|
@cask.metadata_master_container_path.rmdir_if_possible unless upgrade?
|
||||||
|
|
||||||
# toplevel staged distribution
|
# toplevel staged distribution
|
||||||
@cask.caskroom_path.rmdir_if_possible unless upgrade
|
@cask.caskroom_path.rmdir_if_possible unless upgrade?
|
||||||
end
|
end
|
||||||
|
|
||||||
def purge_caskroom_path
|
def purge_caskroom_path
|
||||||
|
|||||||
@ -1,24 +1,31 @@
|
|||||||
require_relative "shared_examples/invalid_option"
|
require_relative "shared_examples/invalid_option"
|
||||||
|
|
||||||
describe Hbc::CLI::Upgrade, :cask do
|
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"
|
it_behaves_like "a command that handles invalid options"
|
||||||
|
|
||||||
before(:example) do
|
before(:example) do
|
||||||
installed.each { |cask| InstallHelper.install_with_caskfile(cask) }
|
installed =
|
||||||
|
[
|
||||||
|
"outdated/local-caffeine",
|
||||||
|
"outdated/local-transmission",
|
||||||
|
"outdated/auto-updates",
|
||||||
|
]
|
||||||
|
|
||||||
|
installed.each { |cask| Hbc::CLI::Install.run(cask) }
|
||||||
|
|
||||||
allow_any_instance_of(described_class).to receive(:verbose?).and_return(true)
|
allow_any_instance_of(described_class).to receive(:verbose?).and_return(true)
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'without --greedy it ignores the Casks with "version latest" or "auto_updates true"' do
|
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
|
it "updates all the installed Casks when no token is provided" do
|
||||||
|
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.2")
|
||||||
|
|
||||||
|
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.60")
|
||||||
|
|
||||||
described_class.run
|
described_class.run
|
||||||
|
|
||||||
expect(Hbc::CaskLoader.load("local-caffeine")).to be_installed
|
expect(Hbc::CaskLoader.load("local-caffeine")).to be_installed
|
||||||
@ -31,47 +38,89 @@ describe Hbc::CLI::Upgrade, :cask do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it "updates only the Casks specified in the command line" do
|
it "updates only the Casks specified in the command line" do
|
||||||
|
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.2")
|
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.2")
|
||||||
|
|
||||||
|
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.60")
|
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
||||||
|
|
||||||
described_class.run("local-caffeine")
|
described_class.run("local-caffeine")
|
||||||
|
|
||||||
|
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-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-caffeine").versions).to_not include("1.2.2")
|
||||||
|
|
||||||
|
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.60")
|
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'ignores "auto_updates" and "latest" Casks even when their tokens are provided in the command line' do
|
it 'ignores "auto_updates" and "latest" Casks even when their tokens are provided in the command line' do
|
||||||
|
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.2")
|
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.2")
|
||||||
|
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||||
|
|
||||||
described_class.run("local-caffeine", "auto-updates", "version-latest-string")
|
described_class.run("local-caffeine", "auto-updates")
|
||||||
|
|
||||||
|
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-caffeine").versions).to include("1.2.3")
|
||||||
|
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "with --greedy it checks additional Casks" do
|
describe "with --greedy it checks additional Casks" do
|
||||||
it 'includes the Casks with "auto_updates true" or "version latest" with --greedy' do
|
it 'includes the Casks with "auto_updates true" or "version latest" with --greedy' do
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||||
|
|
||||||
|
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.2")
|
expect(Hbc::CaskLoader.load("local-caffeine").versions).to include("1.2.2")
|
||||||
|
|
||||||
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.60")
|
||||||
|
|
||||||
described_class.run("--greedy")
|
described_class.run("--greedy")
|
||||||
|
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
||||||
|
|
||||||
|
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-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")
|
expect(Hbc::CaskLoader.load("local-transmission").versions).to include("2.61")
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'does not include the Casks with "auto_updates true" when the version did not change' do
|
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"))
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
InstallHelper.install_with_caskfile(cask)
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.57")
|
||||||
|
|
||||||
|
described_class.run("auto-updates", "--greedy")
|
||||||
|
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
||||||
|
|
||||||
described_class.run("auto-updates", "--greedy")
|
described_class.run("auto-updates", "--greedy")
|
||||||
|
|
||||||
|
expect(Hbc::CaskLoader.load("auto-updates")).to be_installed
|
||||||
|
expect(Hbc.appdir.join("MyFancyApp.app")).to be_a_directory
|
||||||
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
expect(Hbc::CaskLoader.load("auto-updates").versions).to include("2.61")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -1,11 +1,11 @@
|
|||||||
cask 'auto-updates' do
|
cask 'auto-updates' do
|
||||||
version '2.61'
|
version '2.61'
|
||||||
sha256 'e44ffa103fbf83f55c8d0b1bea309a43b2880798dae8620b1ee8da5e1095ec68'
|
sha256 '5633c3a0f2e572cbf021507dec78c50998b398c343232bdfc7e26221d0a5db4d'
|
||||||
|
|
||||||
url "file://#{TEST_FIXTURE_DIR}/cask/transmission-2.61.dmg"
|
url "file://#{TEST_FIXTURE_DIR}/cask/MyFancyApp.zip"
|
||||||
homepage 'http://example.com/auto-updates'
|
homepage 'http://example.com/MyFancyApp'
|
||||||
|
|
||||||
auto_updates true
|
auto_updates true
|
||||||
|
|
||||||
app 'Transmission.app'
|
app 'MyFancyApp/MyFancyApp.app'
|
||||||
end
|
end
|
||||||
|
|||||||
@ -1,11 +1,11 @@
|
|||||||
cask 'auto-updates' do
|
cask 'auto-updates' do
|
||||||
version '2.57'
|
version '2.57'
|
||||||
sha256 'e44ffa103fbf83f55c8d0b1bea309a43b2880798dae8620b1ee8da5e1095ec68'
|
sha256 '5633c3a0f2e572cbf021507dec78c50998b398c343232bdfc7e26221d0a5db4d'
|
||||||
|
|
||||||
url "file://#{TEST_FIXTURE_DIR}/cask/transmission-2.61.dmg"
|
url "file://#{TEST_FIXTURE_DIR}/cask/MyFancyApp.zip"
|
||||||
homepage 'http://example.com/auto-updates'
|
homepage 'http://example.com/MyFancyApp'
|
||||||
|
|
||||||
auto_updates true
|
auto_updates true
|
||||||
|
|
||||||
app 'Transmission.app'
|
app 'MyFancyApp/MyFancyApp.app'
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user