brew/Library/Homebrew/test/patch_spec.rb

107 lines
2.9 KiB
Ruby
Raw Normal View History

2020-10-10 14:16:11 +02:00
# typed: false
# frozen_string_literal: true
2017-02-15 15:19:06 +01:00
require "patch"
describe Patch do
describe "#create" do
context "simple patch" do
subject { described_class.create(:p2, nil) }
2017-02-15 15:19:06 +01:00
it { is_expected.to be_kind_of ExternalPatch }
it { is_expected.to be_external }
its(:strip) { is_expected.to eq(:p2) }
end
context "string patch" do
subject { described_class.create(:p0, "foo") }
2017-02-15 15:19:06 +01:00
it { is_expected.to be_kind_of StringPatch }
its(:strip) { is_expected.to eq(:p0) }
end
context "string patch without strip" do
subject { described_class.create("foo", nil) }
2017-02-15 15:19:06 +01:00
it { is_expected.to be_kind_of StringPatch }
its(:strip) { is_expected.to eq(:p1) }
end
context "data patch" do
subject { described_class.create(:p0, :DATA) }
2017-02-15 15:19:06 +01:00
it { is_expected.to be_kind_of DATAPatch }
its(:strip) { is_expected.to eq(:p0) }
end
context "data patch without strip" do
subject { described_class.create(:DATA, nil) }
2017-02-15 15:19:06 +01:00
it { is_expected.to be_kind_of DATAPatch }
its(:strip) { is_expected.to eq(:p1) }
end
it "raises an error for unknown values" do
expect {
described_class.create(Object.new)
}.to raise_error(ArgumentError)
expect {
described_class.create(Object.new, Object.new)
}.to raise_error(ArgumentError)
end
end
describe "#patch_files" do
subject { described_class.create(:p2, nil) }
context "empty patch" do
2018-01-21 08:29:38 -08:00
its(:resource) { is_expected.to be_kind_of Resource::PatchResource }
2017-02-15 15:19:06 +01:00
its(:patch_files) { is_expected.to eq(subject.resource.patch_files) }
its(:patch_files) { is_expected.to eq([]) }
end
it "returns applied patch files" do
subject.resource.apply("patch1.diff")
expect(subject.patch_files).to eq(["patch1.diff"])
subject.resource.apply("patch2.diff", "patch3.diff")
expect(subject.patch_files).to eq(["patch1.diff", "patch2.diff", "patch3.diff"])
subject.resource.apply(["patch4.diff", "patch5.diff"])
expect(subject.patch_files.count).to eq(5)
subject.resource.apply("patch4.diff", ["patch5.diff", "patch6.diff"], "patch7.diff")
expect(subject.patch_files.count).to eq(7)
end
end
end
describe EmbeddedPatch do
describe "#new" do
subject { described_class.new(:p1) }
2017-02-15 15:19:06 +01:00
its(:inspect) { is_expected.to eq("#<EmbeddedPatch: :p1>") }
end
end
describe ExternalPatch do
subject { described_class.new(:p1) { url "file:///my.patch" } }
describe "#url" do
its(:url) { is_expected.to eq("file:///my.patch") }
end
describe "#inspect" do
its(:inspect) { is_expected.to eq('#<ExternalPatch: :p1 "file:///my.patch">') }
end
describe "#cached_download" do
before do
2017-02-15 15:19:06 +01:00
allow(subject.resource).to receive(:cached_download).and_return("/tmp/foo.tar.gz")
end
its(:cached_download) { is_expected.to eq("/tmp/foo.tar.gz") }
end
end