brew/Library/Homebrew/test/cask/cli/fetch_spec.rb

64 lines
2.0 KiB
Ruby
Raw Normal View History

2017-03-05 19:26:56 +01:00
describe Hbc::CLI::Fetch, :cask do
2016-08-18 22:11:42 +03:00
let(:local_transmission) {
Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/local-transmission.rb")
2016-08-18 22:11:42 +03:00
}
let(:local_caffeine) {
Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/local-caffeine.rb")
2016-08-18 22:11:42 +03:00
}
it "allows download the installer of a Cask" do
2017-07-29 19:55:05 +02:00
Hbc::CLI::Fetch.run("local-transmission", "local-caffeine")
2017-02-08 12:12:52 +01:00
expect(Hbc::CurlDownloadStrategy.new(local_transmission).cached_location).to exist
expect(Hbc::CurlDownloadStrategy.new(local_caffeine).cached_location).to exist
2016-08-18 22:11:42 +03:00
end
it "prevents double fetch (without nuking existing installation)" do
download_stategy = Hbc::CurlDownloadStrategy.new(local_transmission)
2017-07-29 19:55:05 +02:00
Hbc::Download.new(local_transmission).perform
2016-08-18 22:11:42 +03:00
old_ctime = File.stat(download_stategy.cached_location).ctime
2017-07-29 19:55:05 +02:00
Hbc::CLI::Fetch.run("local-transmission")
2016-08-18 22:11:42 +03:00
new_ctime = File.stat(download_stategy.cached_location).ctime
2017-02-08 12:12:52 +01:00
expect(old_ctime.to_i).to eq(new_ctime.to_i)
2016-08-18 22:11:42 +03:00
end
it "allows double fetch with --force" do
2017-07-29 19:55:05 +02:00
Hbc::Download.new(local_transmission).perform
2016-08-18 22:11:42 +03:00
download_stategy = Hbc::CurlDownloadStrategy.new(local_transmission)
old_ctime = File.stat(download_stategy.cached_location).ctime
sleep(1)
2017-07-29 19:55:05 +02:00
Hbc::CLI::Fetch.run("local-transmission", "--force")
2016-08-18 22:11:42 +03:00
download_stategy = Hbc::CurlDownloadStrategy.new(local_transmission)
new_ctime = File.stat(download_stategy.cached_location).ctime
2017-02-08 12:12:52 +01:00
expect(new_ctime.to_i).to be > old_ctime.to_i
2016-08-18 22:11:42 +03:00
end
it "properly handles Casks that are not present" do
2017-02-08 12:12:52 +01:00
expect {
2017-07-29 19:55:05 +02:00
Hbc::CLI::Fetch.run("notacask")
}.to raise_error(Hbc::CaskError, "Fetch incomplete.")
2016-08-18 22:11:42 +03:00
end
describe "when no Cask is specified" do
it "raises an exception" do
2017-02-08 12:12:52 +01:00
expect {
2016-08-18 22:11:42 +03:00
Hbc::CLI::Fetch.run
2017-02-08 12:12:52 +01:00
}.to raise_error(Hbc::CaskUnspecifiedError)
2016-08-18 22:11:42 +03:00
end
end
describe "when no Cask is specified, but an invalid option" do
it "raises an exception" do
2017-02-08 12:12:52 +01:00
expect {
2016-08-18 22:11:42 +03:00
Hbc::CLI::Fetch.run("--notavalidoption")
2017-05-21 02:32:46 +02:00
}.to raise_error(/invalid option/)
2016-08-18 22:11:42 +03:00
end
end
end