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) {
|
2016-12-06 16:36:34 +01:00
|
|
|
Hbc::CaskLoader.load_from_file(TEST_FIXTURE_DIR/"cask/Casks/local-transmission.rb")
|
2016-08-18 22:11:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
let(:local_caffeine) {
|
2016-12-06 16:36:34 +01:00
|
|
|
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")
|
2017-09-11 08:37:15 +02:00
|
|
|
}.to raise_error(Hbc::CaskUnavailableError)
|
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
|