2017-03-06 04:31:16 +01:00
|
|
|
describe Hbc::Verify::Checksum, :cask do
|
2016-08-18 22:11:42 +03:00
|
|
|
let(:cask) { double("cask") }
|
|
|
|
let(:downloaded_path) { double("downloaded_path") }
|
|
|
|
let(:verification) { described_class.new(cask, downloaded_path) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(cask).to receive(:sha256).and_return(sha256)
|
|
|
|
end
|
|
|
|
|
|
|
|
around do |example|
|
|
|
|
shutup { example.run }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".me?" do
|
|
|
|
subject { described_class.me?(cask) }
|
|
|
|
|
|
|
|
context "sha256 is :no_check" do
|
|
|
|
let(:sha256) { :no_check }
|
|
|
|
|
2016-08-27 11:52:14 +02:00
|
|
|
it { is_expected.to be false }
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 is nil" do
|
|
|
|
let(:sha256) { nil }
|
|
|
|
|
2016-08-27 11:52:14 +02:00
|
|
|
it { is_expected.to be true }
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 is empty" do
|
|
|
|
let(:sha256) { "" }
|
|
|
|
|
2016-08-27 11:52:14 +02:00
|
|
|
it { is_expected.to be true }
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 is a valid shasum" do
|
2017-02-08 07:24:41 +01:00
|
|
|
let(:sha256) { "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef" }
|
2016-08-18 22:11:42 +03:00
|
|
|
|
2016-08-27 11:52:14 +02:00
|
|
|
it { is_expected.to be true }
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#verify" do
|
|
|
|
subject { verification.verify }
|
|
|
|
|
2017-02-08 07:24:41 +01:00
|
|
|
let(:computed) { "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef" }
|
2016-08-18 22:11:42 +03:00
|
|
|
|
|
|
|
before do
|
|
|
|
allow(verification).to receive(:computed).and_return(computed)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 matches computed" do
|
|
|
|
let(:sha256) { computed }
|
|
|
|
|
|
|
|
it "does not raise an error" do
|
2016-08-27 11:52:14 +02:00
|
|
|
expect { subject }.not_to raise_error
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 is :no_check" do
|
|
|
|
let(:sha256) { :no_check }
|
|
|
|
|
|
|
|
it "does not raise an error" do
|
2016-08-27 11:52:14 +02:00
|
|
|
expect { subject }.not_to raise_error
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 does not match computed" do
|
2017-02-08 07:24:41 +01:00
|
|
|
let(:sha256) { "d3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33f" }
|
2016-08-18 22:11:42 +03:00
|
|
|
|
|
|
|
it "raises an error" do
|
|
|
|
expect { subject }.to raise_error(Hbc::CaskSha256MismatchError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 is nil" do
|
|
|
|
let(:sha256) { nil }
|
|
|
|
|
|
|
|
it "raises an error" do
|
|
|
|
expect { subject }.to raise_error(Hbc::CaskSha256MissingError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "sha256 is empty" do
|
|
|
|
let(:sha256) { "" }
|
|
|
|
|
|
|
|
it "raises an error" do
|
|
|
|
expect { subject }.to raise_error(Hbc::CaskSha256MissingError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|