2021-08-06 02:30:44 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require "api"
|
|
|
|
|
|
|
|
describe Homebrew::API do
|
|
|
|
let(:text) { "foo" }
|
|
|
|
let(:json) { '{"foo":"bar"}' }
|
|
|
|
let(:json_hash) { JSON.parse(json) }
|
2022-12-30 01:54:32 -05:00
|
|
|
let(:json_invalid) { '{"foo":"bar"' }
|
2021-08-06 02:30:44 -04:00
|
|
|
|
2023-02-16 12:05:38 +00:00
|
|
|
before do
|
|
|
|
described_class.clear_cache
|
|
|
|
end
|
|
|
|
|
2021-08-06 02:30:44 -04:00
|
|
|
def mock_curl_output(stdout: "", success: true)
|
2023-02-28 12:24:22 -08:00
|
|
|
curl_output = instance_double(SystemCommand::Result, stdout: stdout, success?: success)
|
2021-08-06 02:30:44 -04:00
|
|
|
allow(Utils::Curl).to receive(:curl_output).and_return curl_output
|
|
|
|
end
|
|
|
|
|
2022-12-30 01:54:32 -05:00
|
|
|
def mock_curl_download(stdout:)
|
|
|
|
allow(Utils::Curl).to receive(:curl_download) do |*_args, **kwargs|
|
|
|
|
kwargs[:to].write stdout
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-08-06 02:30:44 -04:00
|
|
|
describe "::fetch" do
|
|
|
|
it "fetches a JSON file" do
|
|
|
|
mock_curl_output stdout: json
|
2021-08-09 11:00:00 -04:00
|
|
|
fetched_json = described_class.fetch("foo.json")
|
2021-08-06 02:30:44 -04:00
|
|
|
expect(fetched_json).to eq json_hash
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if the file does not exist" do
|
|
|
|
mock_curl_output success: false
|
|
|
|
expect { described_class.fetch("bar.txt") }.to raise_error(ArgumentError, /No file found/)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if the JSON file is invalid" do
|
|
|
|
mock_curl_output stdout: text
|
2021-08-09 11:00:00 -04:00
|
|
|
expect { described_class.fetch("baz.txt") }.to raise_error(ArgumentError, /Invalid JSON file/)
|
2021-08-06 02:30:44 -04:00
|
|
|
end
|
|
|
|
end
|
2022-12-30 01:54:32 -05:00
|
|
|
|
|
|
|
describe "::fetch_json_api_file" do
|
|
|
|
let!(:cache_dir) { mktmpdir }
|
|
|
|
|
|
|
|
before do
|
|
|
|
(cache_dir/"bar.json").write "tmp"
|
|
|
|
end
|
|
|
|
|
|
|
|
it "fetches a JSON file" do
|
|
|
|
mock_curl_download stdout: json
|
2023-02-16 21:49:03 +00:00
|
|
|
fetched_json, = described_class.fetch_json_api_file("foo.json", target: cache_dir/"foo.json")
|
2022-12-30 01:54:32 -05:00
|
|
|
expect(fetched_json).to eq json_hash
|
|
|
|
end
|
|
|
|
|
|
|
|
it "updates an existing JSON file" do
|
|
|
|
mock_curl_download stdout: json
|
2023-02-16 21:49:03 +00:00
|
|
|
fetched_json, = described_class.fetch_json_api_file("bar.json", target: cache_dir/"bar.json")
|
2022-12-30 01:54:32 -05:00
|
|
|
expect(fetched_json).to eq json_hash
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if the JSON file is invalid" do
|
|
|
|
mock_curl_download stdout: json_invalid
|
2023-03-08 23:14:46 +00:00
|
|
|
expect do
|
2022-12-30 01:54:32 -05:00
|
|
|
described_class.fetch_json_api_file("baz.json", target: cache_dir/"baz.json")
|
2023-03-08 23:14:46 +00:00
|
|
|
end.to raise_error(SystemExit)
|
2022-12-30 01:54:32 -05:00
|
|
|
end
|
|
|
|
end
|
2024-02-16 23:19:39 +01:00
|
|
|
|
|
|
|
describe "::tap_from_source_download" do
|
|
|
|
let(:api_cache_root) { Homebrew::API::HOMEBREW_CACHE_API_SOURCE }
|
|
|
|
let(:cache_path) do
|
|
|
|
api_cache_root/"Homebrew"/"homebrew-core"/"cf5c386c1fa2cb54279d78c0990dd7a0fa4bc327"/"Formula"/"foo.rb"
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when given a path inside the API source cache" do
|
|
|
|
it "returns the corresponding tap" do
|
|
|
|
expect(described_class.tap_from_source_download(cache_path)).to eq CoreTap.instance
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when given a path that is not inside the API source cache" do
|
|
|
|
let(:api_cache_root) { mktmpdir }
|
|
|
|
|
|
|
|
it "returns nil" do
|
|
|
|
expect(described_class.tap_from_source_download(cache_path)).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when given a relative path that is not inside the API source cache" do
|
|
|
|
it "returns nil" do
|
|
|
|
expect(described_class.tap_from_source_download(Pathname("../foo.rb"))).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2021-08-06 02:30:44 -04:00
|
|
|
end
|