Merge pull request #4434 from reitermarkus/simplify-sha256
Remove unused `incremental_hash` method.
This commit is contained in:
commit
bef2765dd7
@ -29,7 +29,7 @@ module Hbc
|
|||||||
end
|
end
|
||||||
|
|
||||||
def computed
|
def computed
|
||||||
@computed ||= Digest::SHA2.file(downloaded_path).hexdigest
|
@computed ||= downloaded_path.sha256
|
||||||
end
|
end
|
||||||
|
|
||||||
def verify_checksum
|
def verify_checksum
|
||||||
|
@ -309,21 +309,9 @@ class Pathname
|
|||||||
/^#!\s*\S+/ =~ open("r") { |f| f.read(1024) }
|
/^#!\s*\S+/ =~ open("r") { |f| f.read(1024) }
|
||||||
end
|
end
|
||||||
|
|
||||||
# @private
|
|
||||||
def incremental_hash(klass)
|
|
||||||
digest = klass.new
|
|
||||||
if digest.respond_to?(:file)
|
|
||||||
digest.file(self)
|
|
||||||
else
|
|
||||||
buf = ""
|
|
||||||
open("rb") { |f| digest << buf while f.read(16384, buf) }
|
|
||||||
end
|
|
||||||
digest.hexdigest
|
|
||||||
end
|
|
||||||
|
|
||||||
def sha256
|
def sha256
|
||||||
require "digest/sha2"
|
require "digest/sha2"
|
||||||
incremental_hash(Digest::SHA256)
|
Digest::SHA256.file(self).hexdigest
|
||||||
end
|
end
|
||||||
|
|
||||||
def verify_checksum(expected)
|
def verify_checksum(expected)
|
||||||
|
@ -1,35 +1,35 @@
|
|||||||
describe Hbc::Verify::Checksum, :cask do
|
describe Hbc::Verify::Checksum, :cask do
|
||||||
let(:cask) { double("cask", token: "cask") }
|
let(:cask) { double("cask", token: "cask") }
|
||||||
let(:downloaded_path) { double("downloaded_path") }
|
let(:downloaded_path) { instance_double("Pathname") }
|
||||||
let(:verification) { described_class.new(cask, downloaded_path) }
|
let(:verification) { described_class.new(cask, downloaded_path) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
allow(cask).to receive(:sha256).and_return(sha256)
|
allow(cask).to receive(:sha256).and_return(expected_sha256)
|
||||||
end
|
end
|
||||||
|
|
||||||
describe ".me?" do
|
describe ".me?" do
|
||||||
subject { described_class.me?(cask) }
|
subject { described_class.me?(cask) }
|
||||||
|
|
||||||
context "sha256 is :no_check" do
|
context "when expected sha256 is :no_check" do
|
||||||
let(:sha256) { :no_check }
|
let(:expected_sha256) { :no_check }
|
||||||
|
|
||||||
it { is_expected.to be false }
|
it { is_expected.to be false }
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 is nil" do
|
context "when expected sha256 is nil" do
|
||||||
let(:sha256) { nil }
|
let(:expected_sha256) { nil }
|
||||||
|
|
||||||
it { is_expected.to be true }
|
it { is_expected.to be true }
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 is empty" do
|
context "sha256 is empty" do
|
||||||
let(:sha256) { "" }
|
let(:expected_sha256) { "" }
|
||||||
|
|
||||||
it { is_expected.to be true }
|
it { is_expected.to be true }
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 is a valid shasum" do
|
context "when expected sha256 is a valid shasum" do
|
||||||
let(:sha256) { "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef" }
|
let(:expected_sha256) { "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef" }
|
||||||
|
|
||||||
it { is_expected.to be true }
|
it { is_expected.to be true }
|
||||||
end
|
end
|
||||||
@ -38,46 +38,47 @@ describe Hbc::Verify::Checksum, :cask do
|
|||||||
describe "#verify" do
|
describe "#verify" do
|
||||||
subject { verification.verify }
|
subject { verification.verify }
|
||||||
|
|
||||||
let(:computed) { "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef" }
|
|
||||||
|
|
||||||
before do
|
before do
|
||||||
allow(verification).to receive(:computed).and_return(computed)
|
allow(cask).to receive(:sha256).and_return(expected_sha256)
|
||||||
|
allow(downloaded_path).to receive(:sha256).and_return(actual_sha256)
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 matches computed" do
|
let(:actual_sha256) { "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef" }
|
||||||
let(:sha256) { computed }
|
|
||||||
|
context "when expected matches actual sha256" do
|
||||||
|
let(:expected_sha256) { actual_sha256 }
|
||||||
|
|
||||||
it "does not raise an error" do
|
it "does not raise an error" do
|
||||||
expect { subject }.not_to raise_error
|
expect { subject }.not_to raise_error
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 is :no_check" do
|
context "when expected sha256 is :no_check" do
|
||||||
let(:sha256) { :no_check }
|
let(:expected_sha256) { :no_check }
|
||||||
|
|
||||||
it "does not raise an error" do
|
it "does not raise an error" do
|
||||||
expect { subject }.not_to raise_error
|
expect { subject }.not_to raise_error
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 does not match computed" do
|
context "when expected does not match sha256" do
|
||||||
let(:sha256) { "d3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33f" }
|
let(:expected_sha256) { "d3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33fd3adb33f" }
|
||||||
|
|
||||||
it "raises an error" do
|
it "raises an error" do
|
||||||
expect { subject }.to raise_error(Hbc::CaskSha256MismatchError)
|
expect { subject }.to raise_error(Hbc::CaskSha256MismatchError)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 is nil" do
|
context "when expected sha256 is nil" do
|
||||||
let(:sha256) { nil }
|
let(:expected_sha256) { nil }
|
||||||
|
|
||||||
it "raises an error" do
|
it "raises an error" do
|
||||||
expect { subject }.to raise_error(Hbc::CaskSha256MissingError)
|
expect { subject }.to raise_error(Hbc::CaskSha256MissingError)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "sha256 is empty" do
|
context "when expected sha256 is empty" do
|
||||||
let(:sha256) { "" }
|
let(:expected_sha256) { "" }
|
||||||
|
|
||||||
it "raises an error" do
|
it "raises an error" do
|
||||||
expect { subject }.to raise_error(Hbc::CaskSha256MissingError)
|
expect { subject }.to raise_error(Hbc::CaskSha256MissingError)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user