2020-10-10 14:16:11 +02:00
|
|
|
# typed: false
|
2019-04-19 15:38:03 +09:00
|
|
|
# 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) }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
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") }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
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) }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
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) }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
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) }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
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) }
|
2018-03-25 13:30:37 +01:00
|
|
|
|
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
|
2018-03-25 13:30:37 +01:00
|
|
|
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
|