move cask/cmd/uninstall_spec to cask/uninstall_spec
This commit is contained in:
parent
db328b59f2
commit
cd0686d75b
@ -1,7 +1,9 @@
|
||||
# typed: false
|
||||
# frozen_string_literal: true
|
||||
|
||||
describe Cask::Cmd::Uninstall, :cask do
|
||||
require "cask/uninstall"
|
||||
|
||||
describe Cask::Uninstall, :cask do
|
||||
it "displays the uninstallation progress" do
|
||||
caffeine = Cask::CaskLoader.load(cask_path("local-caffeine"))
|
||||
|
||||
@ -15,23 +17,22 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
EOS
|
||||
|
||||
expect do
|
||||
described_class.run("local-caffeine")
|
||||
described_class.uninstall_casks(caffeine)
|
||||
end.to output(output).to_stdout
|
||||
end
|
||||
|
||||
it "shows an error when a bad Cask is provided" do
|
||||
expect { described_class.run("notacask") }
|
||||
.to raise_error(Cask::CaskUnavailableError, /is unavailable/)
|
||||
end
|
||||
|
||||
it "shows an error when a Cask is provided that's not installed" do
|
||||
expect { described_class.run("local-caffeine") }
|
||||
caffeine = Cask::CaskLoader.load(cask_path("local-caffeine"))
|
||||
|
||||
expect { described_class.uninstall_casks(caffeine) }
|
||||
.to raise_error(Cask::CaskNotInstalledError, /is not installed/)
|
||||
end
|
||||
|
||||
it "tries anyway on a non-present Cask when --force is given" do
|
||||
caffeine = Cask::CaskLoader.load(cask_path("local-caffeine"))
|
||||
|
||||
expect do
|
||||
described_class.run("local-caffeine", "--force")
|
||||
described_class.uninstall_casks(caffeine, force: true)
|
||||
end.not_to raise_error
|
||||
end
|
||||
|
||||
@ -45,7 +46,7 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
expect(caffeine).to be_installed
|
||||
expect(transmission).to be_installed
|
||||
|
||||
described_class.run("local-caffeine", "local-transmission")
|
||||
described_class.uninstall_casks(caffeine, transmission)
|
||||
|
||||
expect(caffeine).not_to be_installed
|
||||
expect(caffeine.config.appdir.join("Transmission.app")).not_to exist
|
||||
@ -62,13 +63,13 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
|
||||
cask.config.appdir.join("MyFancyApp.app").rmtree
|
||||
|
||||
expect { described_class.run("with-uninstall-script-app") }
|
||||
expect { described_class.uninstall_casks(cask) }
|
||||
.to raise_error(Cask::CaskError, /uninstall script .* does not exist/)
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect do
|
||||
described_class.run("with-uninstall-script-app", "--force")
|
||||
described_class.uninstall_casks(cask, force: true)
|
||||
end.not_to raise_error
|
||||
|
||||
expect(cask).not_to be_installed
|
||||
@ -85,6 +86,7 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
]
|
||||
end
|
||||
let(:caskroom_path) { Cask::Caskroom.path.join(token).tap(&:mkpath) }
|
||||
# let(:versioned_cask) { Cask::CaskLoader.load(caskroom_path) }
|
||||
|
||||
before do
|
||||
timestamped_versions.each do |timestamped_version|
|
||||
@ -101,13 +103,13 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
end
|
||||
|
||||
it "uninstalls one version at a time" do
|
||||
described_class.run("versioned-cask")
|
||||
described_class.uninstall_casks(Cask::Cask.new("versioned-cask"))
|
||||
|
||||
expect(caskroom_path.join(first_installed_version)).to exist
|
||||
expect(caskroom_path.join(last_installed_version)).not_to exist
|
||||
expect(caskroom_path).to exist
|
||||
|
||||
described_class.run("versioned-cask")
|
||||
described_class.uninstall_casks(Cask::Cask.new("versioned-cask"))
|
||||
|
||||
expect(caskroom_path.join(first_installed_version)).not_to exist
|
||||
expect(caskroom_path).not_to exist
|
||||
@ -116,7 +118,7 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
it "displays a message when versions remain installed" do
|
||||
expect do
|
||||
expect do
|
||||
described_class.run("versioned-cask")
|
||||
described_class.uninstall_casks(Cask::Cask.new("versioned-cask"))
|
||||
end.not_to output.to_stderr
|
||||
end.to output(/#{token} #{first_installed_version} is still installed./).to_stdout
|
||||
end
|
||||
@ -125,6 +127,7 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
context "when Casks in Taps have been renamed or removed" do
|
||||
let(:app) { Cask::Config.new.appdir.join("ive-been-renamed.app") }
|
||||
let(:caskroom_path) { Cask::Caskroom.path.join("ive-been-renamed").tap(&:mkpath) }
|
||||
# let(:ive_been_renamed) { Cask::CaskLoader.load(caskroom_path) }
|
||||
let(:saved_caskfile) do
|
||||
caskroom_path.join(".metadata", "latest", "timestamp", "Casks").join("ive-been-renamed.rb")
|
||||
end
|
||||
@ -148,7 +151,7 @@ describe Cask::Cmd::Uninstall, :cask do
|
||||
end
|
||||
|
||||
it "can still uninstall them" do
|
||||
described_class.run("ive-been-renamed")
|
||||
described_class.uninstall_casks(Cask::Cask.new("ive-been-renamed"))
|
||||
|
||||
expect(app).not_to exist
|
||||
expect(caskroom_path).not_to exist
|
||||
Loading…
x
Reference in New Issue
Block a user