remove cask/cmd specs
This commit is contained in:
parent
6343a06f3c
commit
cba118533b
@ -1,131 +0,0 @@
|
||||
# typed: false
|
||||
# frozen_string_literal: true
|
||||
|
||||
describe Cask::Cmd::Install, :cask do
|
||||
it "displays the installation progress" do
|
||||
output = Regexp.new <<~EOS
|
||||
==> Downloading file:.*caffeine.zip
|
||||
==> Installing Cask local-caffeine
|
||||
==> Moving App 'Caffeine.app' to '.*Caffeine.app'
|
||||
.*local-caffeine was successfully installed!
|
||||
EOS
|
||||
|
||||
expect do
|
||||
described_class.run("local-caffeine")
|
||||
end.to output(output).to_stdout
|
||||
end
|
||||
|
||||
it "allows staging and activation of multiple Casks at once" do
|
||||
described_class.run("local-transmission", "local-caffeine")
|
||||
transmission = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
caffeine = Cask::CaskLoader.load(cask_path("local-caffeine"))
|
||||
expect(transmission).to be_installed
|
||||
expect(transmission.config.appdir.join("Transmission.app")).to be_a_directory
|
||||
expect(caffeine).to be_installed
|
||||
expect(caffeine.config.appdir.join("Caffeine.app")).to be_a_directory
|
||||
end
|
||||
|
||||
it "recognizes the --appdir flag" do
|
||||
appdir = mktmpdir
|
||||
|
||||
expect(Cask::CaskLoader).to receive(:load)
|
||||
.with("local-caffeine", any_args)
|
||||
.and_wrap_original { |f, *args|
|
||||
caffeine = f.call(*args)
|
||||
expect(caffeine.config.appdir).to eq appdir
|
||||
caffeine
|
||||
}
|
||||
|
||||
described_class.run("local-caffeine", "--appdir=#{appdir}")
|
||||
end
|
||||
|
||||
it "recognizes the --appdir flag from HOMEBREW_CASK_OPTS" do
|
||||
appdir = mktmpdir
|
||||
|
||||
expect(Cask::CaskLoader).to receive(:load)
|
||||
.with("local-caffeine", any_args)
|
||||
.and_wrap_original { |f, *args|
|
||||
caffeine = f.call(*args)
|
||||
expect(caffeine.config.appdir).to eq appdir
|
||||
caffeine
|
||||
}
|
||||
|
||||
ENV["HOMEBREW_CASK_OPTS"] = "--appdir=#{appdir}"
|
||||
|
||||
described_class.run("local-caffeine")
|
||||
end
|
||||
|
||||
it "prefers an explicit --appdir flag to one from HOMEBREW_CASK_OPTS" do
|
||||
global_appdir = mktmpdir
|
||||
appdir = mktmpdir
|
||||
|
||||
expect(Cask::CaskLoader).to receive(:load)
|
||||
.with("local-caffeine", any_args)
|
||||
.and_wrap_original { |f, *args|
|
||||
caffeine = f.call(*args)
|
||||
expect(caffeine.config.appdir).to eq appdir
|
||||
caffeine
|
||||
}
|
||||
|
||||
ENV["HOMEBREW_CASK_OPTS"] = "--appdir=#{global_appdir}"
|
||||
|
||||
described_class.run("local-caffeine", "--appdir=#{appdir}")
|
||||
end
|
||||
|
||||
it "skips double install (without nuking existing installation)" do
|
||||
described_class.run("local-transmission")
|
||||
described_class.run("local-transmission")
|
||||
expect(Cask::CaskLoader.load(cask_path("local-transmission"))).to be_installed
|
||||
end
|
||||
|
||||
it "prints a warning message on double install" do
|
||||
described_class.run("local-transmission")
|
||||
|
||||
expect do
|
||||
described_class.run("local-transmission")
|
||||
end.to output(/Warning: Cask 'local-transmission' is already installed./).to_stderr
|
||||
end
|
||||
|
||||
it "allows double install with --force" do
|
||||
described_class.run("local-transmission")
|
||||
|
||||
expect do
|
||||
expect do
|
||||
described_class.run("local-transmission", "--force")
|
||||
end.to output(/It seems there is already an App at.*overwriting\./).to_stderr
|
||||
end.to output(/local-transmission was successfully installed!/).to_stdout
|
||||
end
|
||||
|
||||
it "skips dependencies with --skip-cask-deps" do
|
||||
described_class.run("with-depends-on-cask-multiple", "--skip-cask-deps")
|
||||
expect(Cask::CaskLoader.load(cask_path("with-depends-on-cask-multiple"))).to be_installed
|
||||
expect(Cask::CaskLoader.load(cask_path("local-caffeine"))).not_to be_installed
|
||||
expect(Cask::CaskLoader.load(cask_path("local-transmission"))).not_to be_installed
|
||||
end
|
||||
|
||||
it "properly handles Casks that are not present" do
|
||||
expect do
|
||||
described_class.run("notacask")
|
||||
end.to raise_error(Cask::CaskUnavailableError)
|
||||
end
|
||||
|
||||
it "returns a suggestion for a misspelled Cask" do
|
||||
expect do
|
||||
described_class.run("localcaffeine")
|
||||
end.to raise_error(
|
||||
Cask::CaskUnavailableError,
|
||||
"Cask 'localcaffeine' is unavailable: No Cask with this name exists. " \
|
||||
"Did you mean 'local-caffeine'?",
|
||||
)
|
||||
end
|
||||
|
||||
it "returns multiple suggestions for a Cask fragment" do
|
||||
expect do
|
||||
described_class.run("local")
|
||||
end.to raise_error(
|
||||
Cask::CaskUnavailableError,
|
||||
"Cask 'local' is unavailable: No Cask with this name exists. " \
|
||||
"Did you mean one of these?\nlocal-caffeine\nlocal-transmission\n",
|
||||
)
|
||||
end
|
||||
end
|
||||
@ -1,227 +0,0 @@
|
||||
# typed: false
|
||||
# frozen_string_literal: true
|
||||
|
||||
require "cask/cmd/install"
|
||||
require "cask/cask_loader"
|
||||
require "cask/download"
|
||||
require "cask/quarantine"
|
||||
|
||||
describe Cask::Quarantine, :cask do
|
||||
matcher :be_quarantined do
|
||||
match do |path|
|
||||
expect(
|
||||
described_class.detect(path),
|
||||
).to be true
|
||||
end
|
||||
end
|
||||
|
||||
describe "by default" do
|
||||
it "quarantines a nice fresh Cask" do
|
||||
Cask::Cmd::Install.run("local-transmission")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("Transmission.app")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines Cask fetches" do
|
||||
download = Cask::Download.new(Cask::CaskLoader.load("local-transmission"), quarantine: true)
|
||||
download.fetch
|
||||
local_transmission = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
cached_location = Cask::Download.new(local_transmission).fetch
|
||||
|
||||
expect(cached_location).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines Cask installs even if the fetch was not" do
|
||||
download = Cask::Download.new(Cask::CaskLoader.load("local-transmission"), quarantine: false)
|
||||
download.fetch
|
||||
|
||||
Cask::Cmd::Install.run("local-transmission")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("Transmission.app")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines dmg-based Casks" do
|
||||
Cask::Cmd::Install.run("container-dmg")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-dmg"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines tar-gz-based Casks" do
|
||||
Cask::Cmd::Install.run("container-tar-gz")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-tar-gz"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines xar-based Casks" do
|
||||
Cask::Cmd::Install.run("container-xar")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-xar"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines pure bzip2-based Casks" do
|
||||
Cask::Cmd::Install.run("container-bzip2")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-bzip2"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines pure gzip-based Casks" do
|
||||
Cask::Cmd::Install.run("container-gzip")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-gzip"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines the pkg in naked-pkg-based Casks" do
|
||||
Cask::Cmd::Install.run("container-pkg")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-pkg"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.staged_path/"container.pkg").to be_quarantined
|
||||
end
|
||||
|
||||
it "quarantines a nested container" do
|
||||
Cask::Cmd::Install.run("nested-app")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("nested-app"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("MyNestedApp.app")).to be_quarantined
|
||||
end
|
||||
end
|
||||
|
||||
describe "when disabled" do
|
||||
it "does not quarantine even a nice, fresh Cask" do
|
||||
Cask::Cmd::Install.run("local-transmission", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("Transmission.app")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine Cask fetches" do
|
||||
download = Cask::Download.new(Cask::CaskLoader.load("local-transmission"), quarantine: false)
|
||||
download.fetch
|
||||
local_transmission = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
cached_location = Cask::Download.new(local_transmission).fetch
|
||||
|
||||
expect(cached_location).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine Cask installs even if the fetch was" do
|
||||
download = Cask::Download.new(Cask::CaskLoader.load("local-transmission"), quarantine: true)
|
||||
download.fetch
|
||||
|
||||
Cask::Cmd::Install.run("local-transmission", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("local-transmission"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("Transmission.app")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine dmg-based Casks" do
|
||||
Cask::Cmd::Install.run("container-dmg", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-dmg"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine tar-gz-based Casks" do
|
||||
Cask::Cmd::Install.run("container-tar-gz", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-tar-gz"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine xar-based Casks" do
|
||||
Cask::Cmd::Install.run("container-xar", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-xar"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine pure bzip2-based Casks" do
|
||||
Cask::Cmd::Install.run("container-bzip2", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-bzip2"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine pure gzip-based Casks" do
|
||||
Cask::Cmd::Install.run("container-gzip", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("container-gzip"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("container")).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine the pkg in naked-pkg-based Casks" do
|
||||
Cask::Cmd::Install.run("container-pkg", "--no-quarantine")
|
||||
|
||||
naked_pkg = Cask::CaskLoader.load(cask_path("container-pkg"))
|
||||
|
||||
expect(naked_pkg).to be_installed
|
||||
|
||||
expect(
|
||||
Cask::Caskroom.path.join("container-pkg", naked_pkg.version, "container.pkg"),
|
||||
).not_to be_quarantined
|
||||
end
|
||||
|
||||
it "does not quarantine a nested container" do
|
||||
Cask::Cmd::Install.run("nested-app", "--no-quarantine")
|
||||
|
||||
cask = Cask::CaskLoader.load(cask_path("nested-app"))
|
||||
|
||||
expect(cask).to be_installed
|
||||
|
||||
expect(cask.config.appdir.join("MyNestedApp.app")).not_to be_quarantined
|
||||
end
|
||||
end
|
||||
end
|
||||
Loading…
x
Reference in New Issue
Block a user