aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/test/cask
diff options
context:
space:
mode:
authorMarkus Reiter2017-11-27 23:41:03 +0100
committerGitHub2017-11-27 23:41:03 +0100
commitf50ae449800c85b53910bf294b9271c45c25da01 (patch)
treee07111b8e02a4e2005faae4195af6743a5a9f88c /Library/Homebrew/test/cask
parentf7baa3b380c1ed38d78da054c99b1b5f3678a645 (diff)
parent8abe60d2dc3f010112aa671a82e4dceb22c11e5b (diff)
downloadbrew-f50ae449800c85b53910bf294b9271c45c25da01.tar.bz2
Merge pull request #3396 from amyspark/hacktoberfest-upgrade
Implement `brew cask upgrade`
Diffstat (limited to 'Library/Homebrew/test/cask')
-rw-r--r--Library/Homebrew/test/cask/cli/reinstall_spec.rb3
-rw-r--r--Library/Homebrew/test/cask/cli/uninstall_spec.rb3
-rw-r--r--Library/Homebrew/test/cask/cli/upgrade_spec.rb211
3 files changed, 215 insertions, 2 deletions
diff --git a/Library/Homebrew/test/cask/cli/reinstall_spec.rb b/Library/Homebrew/test/cask/cli/reinstall_spec.rb
index 5e551e5b5..3737a7a70 100644
--- a/Library/Homebrew/test/cask/cli/reinstall_spec.rb
+++ b/Library/Homebrew/test/cask/cli/reinstall_spec.rb
@@ -13,7 +13,8 @@ describe Hbc::CLI::Reinstall, :cask do
Already downloaded: .*local-caffeine--1.2.3.zip
==> Verifying checksum for Cask local-caffeine
==> Uninstalling Cask local-caffeine
- ==> Removing App '.*Caffeine.app'.
+ ==> Moving App 'Caffeine.app' back to '.*Caffeine.app'.
+ ==> Purging files for version 1.2.3 of Cask local-caffeine
==> Installing Cask local-caffeine
==> Moving App 'Caffeine.app' to '.*Caffeine.app'.
.*local-caffeine was successfully installed!
diff --git a/Library/Homebrew/test/cask/cli/uninstall_spec.rb b/Library/Homebrew/test/cask/cli/uninstall_spec.rb
index 1ab8f7e4d..345e1b9f2 100644
--- a/Library/Homebrew/test/cask/cli/uninstall_spec.rb
+++ b/Library/Homebrew/test/cask/cli/uninstall_spec.rb
@@ -12,7 +12,8 @@ describe Hbc::CLI::Uninstall, :cask do
output = Regexp.new <<~EOS
==> Uninstalling Cask local-caffeine
- ==> Removing App '.*Caffeine.app'.
+ ==> Moving App 'Caffeine.app' back to '.*Caffeine.app'.
+ ==> Purging files for version 1.2.3 of Cask local-caffeine
EOS
expect {
diff --git a/Library/Homebrew/test/cask/cli/upgrade_spec.rb b/Library/Homebrew/test/cask/cli/upgrade_spec.rb
new file mode 100644
index 000000000..5f389d695
--- /dev/null
+++ b/Library/Homebrew/test/cask/cli/upgrade_spec.rb
@@ -0,0 +1,211 @@
+require_relative "shared_examples/invalid_option"
+
+describe Hbc::CLI::Upgrade, :cask do
+ it_behaves_like "a command that handles invalid options"
+
+ context "successful upgrade" do
+ let(:installed) {
+ [
+ "outdated/local-caffeine",
+ "outdated/local-transmission",
+ "outdated/auto-updates",
+ ]
+ }
+
+ before(:example) do
+ installed.each { |cask| Hbc::CLI::Install.run(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
+ local_caffeine = Hbc::CaskLoader.load("local-caffeine")
+ local_caffeine_path = Hbc.appdir.join("Caffeine.app")
+ local_transmission = Hbc::CaskLoader.load("local-transmission")
+ local_transmission_path = Hbc.appdir.join("Transmission.app")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.2")
+
+ expect(local_transmission).to be_installed
+ expect(local_transmission_path).to be_a_directory
+ expect(local_transmission.versions).to include("2.60")
+
+ described_class.run
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.3")
+
+ expect(local_transmission).to be_installed
+ expect(local_transmission_path).to be_a_directory
+ expect(local_transmission.versions).to include("2.61")
+ end
+
+ it "updates only the Casks specified in the command line" do
+ local_caffeine = Hbc::CaskLoader.load("local-caffeine")
+ local_caffeine_path = Hbc.appdir.join("Caffeine.app")
+ local_transmission = Hbc::CaskLoader.load("local-transmission")
+ local_transmission_path = Hbc.appdir.join("Transmission.app")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.2")
+
+ expect(local_transmission).to be_installed
+ expect(local_transmission_path).to be_a_directory
+ expect(local_transmission.versions).to include("2.60")
+
+ described_class.run("local-caffeine")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.3")
+
+ expect(local_transmission).to be_installed
+ expect(local_transmission_path).to be_a_directory
+ expect(local_transmission.versions).to include("2.60")
+ end
+
+ it 'updates "auto_updates" and "latest" Casks when their tokens are provided in the command line' do
+ local_caffeine = Hbc::CaskLoader.load("local-caffeine")
+ local_caffeine_path = Hbc.appdir.join("Caffeine.app")
+ auto_updates = Hbc::CaskLoader.load("auto-updates")
+ auto_updates_path = Hbc.appdir.join("MyFancyApp.app")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.2")
+
+ expect(auto_updates).to be_installed
+ expect(auto_updates_path).to be_a_directory
+ expect(auto_updates.versions).to include("2.57")
+
+ described_class.run("local-caffeine", "auto-updates")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.3")
+
+ expect(auto_updates).to be_installed
+ expect(auto_updates_path).to be_a_directory
+ expect(auto_updates.versions).to include("2.61")
+ end
+ end
+
+ describe "with --greedy it checks additional Casks" do
+ it 'includes the Casks with "auto_updates true" or "version latest"' do
+ local_caffeine = Hbc::CaskLoader.load("local-caffeine")
+ local_caffeine_path = Hbc.appdir.join("Caffeine.app")
+ auto_updates = Hbc::CaskLoader.load("auto-updates")
+ auto_updates_path = Hbc.appdir.join("MyFancyApp.app")
+ local_transmission = Hbc::CaskLoader.load("local-transmission")
+ local_transmission_path = Hbc.appdir.join("Transmission.app")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.2")
+
+ expect(auto_updates).to be_installed
+ expect(auto_updates_path).to be_a_directory
+ expect(auto_updates.versions).to include("2.57")
+
+ expect(local_transmission).to be_installed
+ expect(local_transmission_path).to be_a_directory
+ expect(local_transmission.versions).to include("2.60")
+
+ described_class.run("--greedy")
+
+ expect(local_caffeine).to be_installed
+ expect(local_caffeine_path).to be_a_directory
+ expect(local_caffeine.versions).to include("1.2.3")
+
+ expect(auto_updates).to be_installed
+ expect(auto_updates_path).to be_a_directory
+ expect(auto_updates.versions).to include("2.61")
+
+ expect(local_transmission).to be_installed
+ expect(local_transmission_path).to be_a_directory
+ expect(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("auto-updates")
+ cask_path = Hbc.appdir.join("MyFancyApp.app")
+
+ expect(cask).to be_installed
+ expect(cask_path).to be_a_directory
+ expect(cask.versions).to include("2.57")
+
+ described_class.run("auto-updates", "--greedy")
+
+ expect(cask).to be_installed
+ expect(cask_path).to be_a_directory
+ expect(cask.versions).to include("2.61")
+
+ described_class.run("auto-updates", "--greedy")
+
+ expect(cask).to be_installed
+ expect(cask_path).to be_a_directory
+ expect(cask.versions).to include("2.61")
+ end
+ end
+ end
+
+ context "failed upgrade" do
+ let(:installed) {
+ [
+ "outdated/bad-checksum",
+ "outdated/will-fail-if-upgraded",
+ ]
+ }
+
+ before(:example) do
+ installed.each { |cask| Hbc::CLI::Install.run(cask) }
+
+ allow_any_instance_of(described_class).to receive(:verbose?).and_return(true)
+ end
+
+ output_reverted = Regexp.new <<~EOS
+ Warning: Reverting upgrade for Cask .*
+ EOS
+
+ it "restores the old Cask if the upgrade failed" do
+ will_fail_if_upgraded = Hbc::CaskLoader.load("will-fail-if-upgraded")
+ will_fail_if_upgraded_path = Hbc.appdir.join("container")
+
+ expect(will_fail_if_upgraded).to be_installed
+ expect(will_fail_if_upgraded_path).to be_a_file
+ expect(will_fail_if_upgraded.versions).to include("1.2.2")
+
+ expect {
+ described_class.run("will-fail-if-upgraded")
+ }.to raise_error(Hbc::CaskError).and output(output_reverted).to_stderr
+
+ expect(will_fail_if_upgraded).to be_installed
+ expect(will_fail_if_upgraded_path).to be_a_file
+ expect(will_fail_if_upgraded.versions).to include("1.2.2")
+ expect(will_fail_if_upgraded.staged_path).to_not exist
+ end
+
+ it "does not restore the old Cask if the upgrade failed pre-install" do
+ bad_checksum = Hbc::CaskLoader.load("bad-checksum")
+ bad_checksum_path = Hbc.appdir.join("Caffeine.app")
+
+ expect(bad_checksum).to be_installed
+ expect(bad_checksum_path).to be_a_directory
+ expect(bad_checksum.versions).to include("1.2.2")
+
+ expect {
+ described_class.run("bad-checksum")
+ }.to raise_error(Hbc::CaskSha256MismatchError).and(not_to_output(output_reverted).to_stderr)
+
+ expect(bad_checksum).to be_installed
+ expect(bad_checksum_path).to be_a_directory
+ expect(bad_checksum.versions).to include("1.2.2")
+ expect(bad_checksum.staged_path).to_not exist
+ end
+ end
+end