2019-04-19 15:38:03 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-03-27 11:49:56 +00:00
|
|
|
require "cmd/shared_examples/args_parse"
|
2020-12-01 19:08:59 +01:00
|
|
|
require "dev-cmd/bottle"
|
2019-03-27 11:49:56 +00:00
|
|
|
|
2024-03-18 12:31:44 -07:00
|
|
|
RSpec.describe Homebrew::DevCmd::Bottle do
|
2025-07-12 02:06:37 +08:00
|
|
|
define_method(:stub_hash) do |parameters|
|
2024-01-26 11:36:08 -08:00
|
|
|
<<~EOS
|
|
|
|
{
|
|
|
|
"#{parameters[:name]}":{
|
|
|
|
"formula":{
|
|
|
|
"pkg_version":"#{parameters[:version]}",
|
|
|
|
"path":"#{parameters[:path]}"
|
|
|
|
},
|
|
|
|
"bottle":{
|
|
|
|
"root_url":"#{parameters[:root_url] || HOMEBREW_BOTTLE_DEFAULT_DOMAIN}",
|
|
|
|
"prefix":"/usr/local",
|
|
|
|
"cellar":"#{parameters[:cellar]}",
|
|
|
|
"rebuild":0,
|
|
|
|
"tags":{
|
|
|
|
"#{parameters[:os]}":{
|
|
|
|
"filename":"#{parameters[:filename]}",
|
|
|
|
"local_filename":"#{parameters[:local_filename]}",
|
|
|
|
"sha256":"#{parameters[:sha256]}"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
2024-03-21 19:48:13 -07:00
|
|
|
it_behaves_like "parseable arguments"
|
2019-03-27 11:49:56 +00:00
|
|
|
|
2024-07-11 18:56:39 +01:00
|
|
|
it "builds a bottle for the given Formula", :integration_test, :needs_network do
|
2019-03-27 09:45:48 +00:00
|
|
|
install_test_formula "testball", build_bottle: true
|
2017-02-23 05:58:30 +01:00
|
|
|
|
2019-03-27 09:45:48 +00:00
|
|
|
# `brew bottle` should not fail with dead symlink
|
|
|
|
# https://github.com/Homebrew/legacy-homebrew/issues/49007
|
|
|
|
(HOMEBREW_CELLAR/"testball/0.1").cd do
|
|
|
|
FileUtils.ln_s "not-exist", "symlink"
|
2017-02-23 05:58:30 +01:00
|
|
|
end
|
2019-03-27 09:45:48 +00:00
|
|
|
|
2019-03-27 11:49:56 +00:00
|
|
|
begin
|
|
|
|
expect { brew "bottle", "--no-rebuild", "testball" }
|
|
|
|
.to output(/testball--0\.1.*\.bottle\.tar\.gz/).to_stdout
|
|
|
|
.and not_to_output.to_stderr
|
|
|
|
.and be_a_success
|
2022-01-18 15:42:01 +08:00
|
|
|
expect(HOMEBREW_CELLAR/"testball-bottle.tar").not_to exist
|
2019-03-27 11:49:56 +00:00
|
|
|
ensure
|
|
|
|
FileUtils.rm_f Dir.glob("testball--0.1*.bottle.tar.gz")
|
|
|
|
end
|
2017-02-23 05:58:30 +01:00
|
|
|
end
|
2020-12-01 19:08:59 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
describe "--merge", :integration_test do
|
2024-03-06 15:10:14 +01:00
|
|
|
let(:core_tap) { CoreTap.instance }
|
2021-02-01 16:14:25 -05:00
|
|
|
let(:tarball) do
|
|
|
|
if OS.linux?
|
|
|
|
TEST_FIXTURE_DIR/"tarballs/testball-0.1-linux.tbz"
|
|
|
|
else
|
|
|
|
TEST_FIXTURE_DIR/"tarballs/testball-0.1.tbz"
|
|
|
|
end
|
|
|
|
end
|
2020-12-09 23:02:31 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
before do
|
2021-02-04 13:30:16 -05:00
|
|
|
Pathname("#{TEST_TMPDIR}/testball-1.0.arm64_big_sur.bottle.json").write stub_hash(
|
|
|
|
name: "testball",
|
|
|
|
version: "1.0",
|
|
|
|
path: "#{core_tap.path}/Formula/testball.rb",
|
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "arm64_big_sur",
|
|
|
|
filename: "testball-1.0.arm64_big_sur.bottle.tar.gz",
|
|
|
|
local_filename: "testball--1.0.arm64_big_sur.bottle.tar.gz",
|
|
|
|
sha256: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149",
|
|
|
|
)
|
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
Pathname("#{TEST_TMPDIR}/testball-1.0.big_sur.bottle.json").write stub_hash(
|
|
|
|
name: "testball",
|
2021-01-29 09:11:35 +00:00
|
|
|
version: "1.0",
|
2021-02-01 16:14:25 -05:00
|
|
|
path: "#{core_tap.path}/Formula/testball.rb",
|
2021-01-29 09:11:35 +00:00
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "big_sur",
|
|
|
|
filename: "hello-1.0.big_sur.bottle.tar.gz",
|
|
|
|
local_filename: "hello--1.0.big_sur.bottle.tar.gz",
|
|
|
|
sha256: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f",
|
2020-12-01 19:08:59 +01:00
|
|
|
)
|
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
Pathname("#{TEST_TMPDIR}/testball-1.0.catalina.bottle.json").write stub_hash(
|
|
|
|
name: "testball",
|
|
|
|
version: "1.0",
|
|
|
|
path: "#{core_tap.path}/Formula/testball.rb",
|
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "catalina",
|
|
|
|
filename: "testball-1.0.catalina.bottle.tar.gz",
|
|
|
|
local_filename: "testball--1.0.catalina.bottle.tar.gz",
|
|
|
|
sha256: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac",
|
|
|
|
)
|
2020-12-31 11:14:25 -08:00
|
|
|
end
|
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
after do
|
2021-02-04 13:30:16 -05:00
|
|
|
FileUtils.rm_f "#{TEST_TMPDIR}/testball-1.0.arm64_big_sur.bottle.json"
|
2021-02-01 16:14:25 -05:00
|
|
|
FileUtils.rm_f "#{TEST_TMPDIR}/testball-1.0.catalina.bottle.json"
|
|
|
|
FileUtils.rm_f "#{TEST_TMPDIR}/testball-1.0.big_sur.bottle.json"
|
2020-12-31 11:14:25 -08:00
|
|
|
end
|
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
it "adds the bottle block to a formula that has none" do
|
|
|
|
core_tap.path.cd do
|
2022-10-07 18:33:58 +01:00
|
|
|
system "git", "-c", "init.defaultBranch=master", "init"
|
2021-02-01 16:14:25 -05:00
|
|
|
setup_test_formula "testball"
|
|
|
|
system "git", "add", "--all"
|
|
|
|
system "git", "commit", "-m", "testball 0.1"
|
|
|
|
end
|
2020-12-31 11:14:25 -08:00
|
|
|
|
2023-03-03 22:13:41 +00:00
|
|
|
# RuboCop would align the `.and` with `.to_stdout` which is too floaty.
|
|
|
|
# rubocop:disable Layout/MultilineMethodCallIndentation
|
2023-03-08 23:14:46 +00:00
|
|
|
expect do
|
2021-02-01 16:14:25 -05:00
|
|
|
brew "bottle",
|
|
|
|
"--merge",
|
|
|
|
"--write",
|
2021-02-04 13:30:16 -05:00
|
|
|
"#{TEST_TMPDIR}/testball-1.0.arm64_big_sur.bottle.json",
|
2021-02-01 16:14:25 -05:00
|
|
|
"#{TEST_TMPDIR}/testball-1.0.big_sur.bottle.json",
|
|
|
|
"#{TEST_TMPDIR}/testball-1.0.catalina.bottle.json"
|
2023-03-08 23:14:46 +00:00
|
|
|
end.to output(Regexp.new(<<~'EOS')).to_stdout
|
2021-02-01 16:14:25 -05:00
|
|
|
==> testball
|
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac"
|
2021-02-01 16:14:25 -05:00
|
|
|
end
|
2021-10-07 15:44:20 +01:00
|
|
|
\[master [0-9a-f]{4,40}\] testball: add 1\.0 bottle\.
|
|
|
|
1 file changed, 6 insertions\(\+\)
|
2021-02-01 16:14:25 -05:00
|
|
|
EOS
|
2021-10-07 15:44:20 +01:00
|
|
|
.and not_to_output.to_stderr
|
|
|
|
.and be_a_success
|
2023-03-03 22:13:41 +00:00
|
|
|
# rubocop:enable Layout/MultilineMethodCallIndentation
|
2021-01-20 23:26:41 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
expect((core_tap.path/"Formula/testball.rb").read).to eq <<~EOS
|
|
|
|
class Testball < Formula
|
|
|
|
desc "Some test"
|
|
|
|
homepage "https://brew.sh/testball"
|
|
|
|
url "file://#{tarball}"
|
|
|
|
sha256 "#{tarball.sha256}"
|
2021-01-20 23:26:41 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac"
|
2021-02-01 16:14:25 -05:00
|
|
|
end
|
2021-01-20 23:26:41 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
option "with-foo", "Build with foo"
|
2021-01-20 23:26:41 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
def install
|
|
|
|
(prefix/"foo"/"test").write("test") if build.with? "foo"
|
|
|
|
prefix.install Dir["*"]
|
|
|
|
(buildpath/"test.c").write \
|
|
|
|
"#include <stdio.h>\\nint main(){printf(\\"test\\");return 0;}"
|
|
|
|
bin.mkpath
|
|
|
|
system ENV.cc, "test.c", "-o", bin/"test"
|
|
|
|
end
|
2020-12-09 23:02:31 +01:00
|
|
|
|
2020-12-22 16:18:51 +01:00
|
|
|
|
2020-12-24 11:55:19 -08:00
|
|
|
|
2021-02-02 15:09:39 -05:00
|
|
|
# something here
|
|
|
|
|
|
|
|
end
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
|
|
|
it "replaces the bottle block in a formula that already has a bottle block" do
|
|
|
|
core_tap.path.cd do
|
2022-10-07 18:33:58 +01:00
|
|
|
system "git", "-c", "init.defaultBranch=master", "init"
|
2021-02-02 15:09:39 -05:00
|
|
|
setup_test_formula "testball", bottle_block: <<~EOS
|
|
|
|
|
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "c3c650d75f5188f5d6edd351dd3215e141b73b8ec1cf9144f30e39cbc45de72e"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "6b276491297d4052538bd2fd22d5129389f27d90a98f831987236a5b90511b98"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "16cf230afdfcb6306c208d169549cf8773c831c8653d2c852315a048960d7e72"
|
2021-02-02 15:09:39 -05:00
|
|
|
end
|
|
|
|
EOS
|
|
|
|
system "git", "add", "--all"
|
|
|
|
system "git", "commit", "-m", "testball 0.1"
|
|
|
|
end
|
|
|
|
|
2023-03-03 22:13:41 +00:00
|
|
|
# RuboCop would align the `.and` with `.to_stdout` which is too floaty.
|
|
|
|
# rubocop:disable Layout/MultilineMethodCallIndentation
|
2023-03-08 23:14:46 +00:00
|
|
|
expect do
|
2021-02-02 15:09:39 -05:00
|
|
|
brew "bottle",
|
|
|
|
"--merge",
|
|
|
|
"--write",
|
2021-02-04 13:30:16 -05:00
|
|
|
"#{TEST_TMPDIR}/testball-1.0.arm64_big_sur.bottle.json",
|
2021-02-02 15:09:39 -05:00
|
|
|
"#{TEST_TMPDIR}/testball-1.0.big_sur.bottle.json",
|
|
|
|
"#{TEST_TMPDIR}/testball-1.0.catalina.bottle.json"
|
2023-03-08 23:14:46 +00:00
|
|
|
end.to output(Regexp.new(<<~'EOS')).to_stdout
|
2021-02-02 15:09:39 -05:00
|
|
|
==> testball
|
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac"
|
2021-02-02 15:09:39 -05:00
|
|
|
end
|
2021-10-07 15:44:20 +01:00
|
|
|
\[master [0-9a-f]{4,40}\] testball: update 1\.0 bottle\.
|
|
|
|
1 file changed, 3 insertions\(\+\), 3 deletions\(\-\)
|
2021-02-02 15:09:39 -05:00
|
|
|
EOS
|
2021-10-07 15:44:20 +01:00
|
|
|
.and not_to_output.to_stderr
|
|
|
|
.and be_a_success
|
2023-03-03 22:13:41 +00:00
|
|
|
# rubocop:enable Layout/MultilineMethodCallIndentation
|
2021-02-02 15:09:39 -05:00
|
|
|
|
|
|
|
expect((core_tap.path/"Formula/testball.rb").read).to eq <<~EOS
|
|
|
|
class Testball < Formula
|
|
|
|
desc "Some test"
|
|
|
|
homepage "https://brew.sh/testball"
|
|
|
|
url "file://#{tarball}"
|
|
|
|
sha256 "#{tarball.sha256}"
|
|
|
|
|
|
|
|
option "with-foo", "Build with foo"
|
|
|
|
|
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac"
|
2021-02-01 16:14:25 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def install
|
|
|
|
(prefix/"foo"/"test").write("test") if build.with? "foo"
|
|
|
|
prefix.install Dir["*"]
|
|
|
|
(buildpath/"test.c").write \
|
|
|
|
"#include <stdio.h>\\nint main(){printf(\\"test\\");return 0;}"
|
2021-02-02 15:09:39 -05:00
|
|
|
bin.mkpath
|
|
|
|
system ENV.cc, "test.c", "-o", bin/"test"
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# something here
|
|
|
|
|
|
|
|
end
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
|
|
|
it "updates the bottle block in a formula that already has a bottle block when using --keep-old" do
|
|
|
|
core_tap.path.cd do
|
2022-10-07 18:33:58 +01:00
|
|
|
system "git", "-c", "init.defaultBranch=master", "init"
|
2021-02-02 15:09:39 -05:00
|
|
|
setup_test_formula "testball", bottle_block: <<~EOS
|
|
|
|
|
|
|
|
bottle do
|
2021-02-01 16:14:25 -05:00
|
|
|
sha256 cellar: :any, high_sierra: "6971b6eebf4c00eaaed72a1104a49be63861eabc95d679a0c84040398e320059"
|
|
|
|
end
|
2021-02-02 15:09:39 -05:00
|
|
|
EOS
|
|
|
|
system "git", "add", "--all"
|
|
|
|
system "git", "commit", "-m", "testball 0.1"
|
|
|
|
end
|
|
|
|
|
2023-03-03 22:13:41 +00:00
|
|
|
# RuboCop would align the `.and` with `.to_stdout` which is too floaty.
|
|
|
|
# rubocop:disable Layout/MultilineMethodCallIndentation
|
2023-03-08 23:14:46 +00:00
|
|
|
expect do
|
2021-02-02 15:09:39 -05:00
|
|
|
brew "bottle",
|
|
|
|
"--merge",
|
|
|
|
"--write",
|
|
|
|
"--keep-old",
|
2021-02-04 13:30:16 -05:00
|
|
|
"#{TEST_TMPDIR}/testball-1.0.arm64_big_sur.bottle.json",
|
2021-02-02 15:09:39 -05:00
|
|
|
"#{TEST_TMPDIR}/testball-1.0.big_sur.bottle.json",
|
|
|
|
"#{TEST_TMPDIR}/testball-1.0.catalina.bottle.json"
|
2023-03-08 23:14:46 +00:00
|
|
|
end.to output(Regexp.new(<<~'EOS')).to_stdout
|
2021-02-02 15:09:39 -05:00
|
|
|
==> testball
|
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac"
|
|
|
|
sha256 cellar: :any, high_sierra: "6971b6eebf4c00eaaed72a1104a49be63861eabc95d679a0c84040398e320059"
|
2021-02-02 15:09:39 -05:00
|
|
|
end
|
2021-10-07 15:44:20 +01:00
|
|
|
\[master [0-9a-f]{4,40}\] testball: update 1\.0 bottle\.
|
|
|
|
1 file changed, 4 insertions\(\+\), 1 deletion\(\-\)
|
2021-02-02 15:09:39 -05:00
|
|
|
EOS
|
2021-10-07 15:44:20 +01:00
|
|
|
.and not_to_output.to_stderr
|
|
|
|
.and be_a_success
|
2023-03-03 22:13:41 +00:00
|
|
|
# rubocop:enable Layout/MultilineMethodCallIndentation
|
2021-02-02 15:09:39 -05:00
|
|
|
|
|
|
|
expect((core_tap.path/"Formula/testball.rb").read).to eq <<~EOS
|
|
|
|
class Testball < Formula
|
|
|
|
desc "Some test"
|
|
|
|
homepage "https://brew.sh/testball"
|
|
|
|
url "file://#{tarball}"
|
|
|
|
sha256 "#{tarball.sha256}"
|
|
|
|
|
|
|
|
option "with-foo", "Build with foo"
|
|
|
|
|
|
|
|
bottle do
|
2021-02-04 13:30:16 -05:00
|
|
|
sha256 cellar: :any_skip_relocation, arm64_big_sur: "8f9aecd233463da6a4ea55f5f88fc5841718c013f3e2a7941350d6130f1dc149"
|
|
|
|
sha256 cellar: :any_skip_relocation, big_sur: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f"
|
|
|
|
sha256 cellar: :any_skip_relocation, catalina: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac"
|
|
|
|
sha256 cellar: :any, high_sierra: "6971b6eebf4c00eaaed72a1104a49be63861eabc95d679a0c84040398e320059"
|
2021-02-02 15:09:39 -05:00
|
|
|
end
|
2020-12-22 16:18:51 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
def install
|
|
|
|
(prefix/"foo"/"test").write("test") if build.with? "foo"
|
|
|
|
prefix.install Dir["*"]
|
|
|
|
(buildpath/"test.c").write \
|
|
|
|
"#include <stdio.h>\\nint main(){printf(\\"test\\");return 0;}"
|
|
|
|
bin.mkpath
|
|
|
|
system ENV.cc, "test.c", "-o", bin/"test"
|
|
|
|
end
|
2020-12-22 16:18:51 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
# something here
|
2020-12-22 16:18:51 +01:00
|
|
|
|
|
|
|
end
|
|
|
|
EOS
|
|
|
|
end
|
2021-02-01 16:14:25 -05:00
|
|
|
end
|
2020-12-22 16:18:51 +01:00
|
|
|
|
2024-03-18 12:31:44 -07:00
|
|
|
describe "bottle_cmd" do
|
|
|
|
subject(:homebrew) { described_class.new(["foo"]) }
|
2020-12-22 16:18:51 +01:00
|
|
|
|
2023-03-08 23:14:46 +00:00
|
|
|
let(:hello_hash_big_sur) do
|
2021-02-01 16:14:25 -05:00
|
|
|
JSON.parse stub_hash(
|
|
|
|
name: "hello",
|
|
|
|
version: "1.0",
|
|
|
|
path: "/home/hello.rb",
|
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "big_sur",
|
|
|
|
filename: "hello-1.0.big_sur.bottle.tar.gz",
|
|
|
|
local_filename: "hello--1.0.big_sur.bottle.tar.gz",
|
|
|
|
sha256: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f",
|
|
|
|
)
|
2023-03-08 23:14:46 +00:00
|
|
|
end
|
|
|
|
let(:hello_hash_catalina) do
|
2021-02-01 16:14:25 -05:00
|
|
|
JSON.parse stub_hash(
|
|
|
|
name: "hello",
|
|
|
|
version: "1.0",
|
|
|
|
path: "/home/hello.rb",
|
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "catalina",
|
|
|
|
filename: "hello-1.0.catalina.bottle.tar.gz",
|
|
|
|
local_filename: "hello--1.0.catalina.bottle.tar.gz",
|
|
|
|
sha256: "5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac",
|
|
|
|
)
|
2023-03-08 23:14:46 +00:00
|
|
|
end
|
|
|
|
let(:unzip_hash_big_sur) do
|
2021-02-01 16:14:25 -05:00
|
|
|
JSON.parse stub_hash(
|
|
|
|
name: "unzip",
|
|
|
|
version: "2.0",
|
|
|
|
path: "/home/unzip.rb",
|
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "big_sur",
|
|
|
|
filename: "unzip-2.0.big_sur.bottle.tar.gz",
|
|
|
|
local_filename: "unzip--2.0.big_sur.bottle.tar.gz",
|
|
|
|
sha256: "16cf230afdfcb6306c208d169549cf8773c831c8653d2c852315a048960d7e72",
|
|
|
|
)
|
2023-03-08 23:14:46 +00:00
|
|
|
end
|
|
|
|
let(:unzip_hash_catalina) do
|
2021-02-01 16:14:25 -05:00
|
|
|
JSON.parse stub_hash(
|
|
|
|
name: "unzip",
|
|
|
|
version: "2.0",
|
|
|
|
path: "/home/unzip.rb",
|
|
|
|
cellar: "any",
|
|
|
|
os: "catalina",
|
|
|
|
filename: "unzip-2.0.catalina.bottle.tar.gz",
|
|
|
|
local_filename: "unzip--2.0.catalina.bottle.tar.gz",
|
|
|
|
sha256: "d9cc50eec8ac243148a121049c236cba06af4a0b1156ab397d0a2850aa79c137",
|
|
|
|
)
|
2023-03-08 23:14:46 +00:00
|
|
|
end
|
2021-02-01 16:14:25 -05:00
|
|
|
|
|
|
|
specify "::parse_json_files" do
|
|
|
|
Tempfile.open("hello--1.0.big_sur.bottle.json") do |f|
|
|
|
|
f.write stub_hash(
|
|
|
|
name: "hello",
|
|
|
|
version: "1.0",
|
|
|
|
path: "/home/hello.rb",
|
|
|
|
cellar: "any_skip_relocation",
|
|
|
|
os: "big_sur",
|
|
|
|
filename: "hello-1.0.big_sur.bottle.tar.gz",
|
|
|
|
local_filename: "hello--1.0.big_sur.bottle.tar.gz",
|
|
|
|
sha256: "a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f",
|
|
|
|
)
|
|
|
|
f.close
|
|
|
|
expect(
|
|
|
|
homebrew.parse_json_files([f.path]).first["hello"]["bottle"]["tags"]["big_sur"]["filename"],
|
|
|
|
).to eq("hello-1.0.big_sur.bottle.tar.gz")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-04-08 17:39:57 +01:00
|
|
|
describe "::merge_json_files" do
|
|
|
|
it "merges JSON files" do
|
|
|
|
bottles_hash = homebrew.merge_json_files(
|
|
|
|
[hello_hash_big_sur, hello_hash_catalina, unzip_hash_big_sur, unzip_hash_catalina],
|
|
|
|
)
|
2021-02-01 16:14:25 -05:00
|
|
|
|
2021-04-08 17:39:57 +01:00
|
|
|
hello_hash = bottles_hash["hello"]
|
|
|
|
expect(hello_hash["bottle"]["tags"]["big_sur"]["cellar"]).to eq("any_skip_relocation")
|
|
|
|
expect(hello_hash["bottle"]["tags"]["big_sur"]["filename"]).to eq("hello-1.0.big_sur.bottle.tar.gz")
|
|
|
|
expect(hello_hash["bottle"]["tags"]["big_sur"]["local_filename"]).to eq("hello--1.0.big_sur.bottle.tar.gz")
|
|
|
|
expect(hello_hash["bottle"]["tags"]["big_sur"]["sha256"]).to eq(
|
|
|
|
"a0af7dcbb5c83f6f3f7ecd507c2d352c1a018f894d51ad241ce8492fa598010f",
|
|
|
|
)
|
|
|
|
expect(hello_hash["bottle"]["tags"]["catalina"]["cellar"]).to eq("any_skip_relocation")
|
|
|
|
expect(hello_hash["bottle"]["tags"]["catalina"]["filename"]).to eq("hello-1.0.catalina.bottle.tar.gz")
|
|
|
|
expect(hello_hash["bottle"]["tags"]["catalina"]["local_filename"]).to eq("hello--1.0.catalina.bottle.tar.gz")
|
|
|
|
expect(hello_hash["bottle"]["tags"]["catalina"]["sha256"]).to eq(
|
|
|
|
"5334dd344986e46b2aa4f0471cac7b0914bd7de7cb890a34415771788d03f2ac",
|
|
|
|
)
|
|
|
|
unzip_hash = bottles_hash["unzip"]
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["big_sur"]["cellar"]).to eq("any_skip_relocation")
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["big_sur"]["filename"]).to eq("unzip-2.0.big_sur.bottle.tar.gz")
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["big_sur"]["local_filename"]).to eq("unzip--2.0.big_sur.bottle.tar.gz")
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["big_sur"]["sha256"]).to eq(
|
|
|
|
"16cf230afdfcb6306c208d169549cf8773c831c8653d2c852315a048960d7e72",
|
|
|
|
)
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["catalina"]["cellar"]).to eq("any")
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["catalina"]["filename"]).to eq("unzip-2.0.catalina.bottle.tar.gz")
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["catalina"]["local_filename"]).to eq("unzip--2.0.catalina.bottle.tar.gz")
|
|
|
|
expect(unzip_hash["bottle"]["tags"]["catalina"]["sha256"]).to eq(
|
|
|
|
"d9cc50eec8ac243148a121049c236cba06af4a0b1156ab397d0a2850aa79c137",
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
# TODO: add deduplication tests e.g.
|
|
|
|
# it "deduplicates JSON files with matching macOS checksums"
|
|
|
|
# it "deduplicates JSON files with matching OS checksums" do
|
2021-02-01 16:14:25 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "#merge_bottle_spec" do
|
|
|
|
it "allows new bottle hash to be empty" do
|
2021-09-16 18:56:47 +01:00
|
|
|
valid_keys = [:root_url, :cellar, :rebuild, :sha256]
|
2021-02-01 16:14:25 -05:00
|
|
|
old_spec = BottleSpecification.new
|
2021-04-09 09:30:36 +01:00
|
|
|
old_spec.sha256(big_sur: "f59bc65c91e4e698f6f050e1efea0040f57372d4dcf0996cbb8f97ced320403b")
|
2021-02-01 16:14:25 -05:00
|
|
|
expect { homebrew.merge_bottle_spec(valid_keys, old_spec, {}) }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
|
|
|
it "checks for conflicting root URL" do
|
|
|
|
old_spec = BottleSpecification.new
|
|
|
|
old_spec.root_url("https://failbrew.bintray.com/bottles")
|
|
|
|
new_hash = { "root_url" => "https://testbrew.bintray.com/bottles" }
|
|
|
|
expect(homebrew.merge_bottle_spec([:root_url], old_spec, new_hash)).to eq [
|
|
|
|
['root_url: old: "https://failbrew.bintray.com/bottles", new: "https://testbrew.bintray.com/bottles"'],
|
|
|
|
[],
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
it "checks for conflicting rebuild number" do
|
|
|
|
old_spec = BottleSpecification.new
|
|
|
|
old_spec.rebuild(1)
|
|
|
|
new_hash = { "rebuild" => 2 }
|
|
|
|
expect(homebrew.merge_bottle_spec([:rebuild], old_spec, new_hash)).to eq [
|
|
|
|
['rebuild: old: "1", new: "2"'],
|
|
|
|
[],
|
|
|
|
]
|
|
|
|
end
|
2020-12-09 23:02:31 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
it "checks for conflicting checksums" do
|
|
|
|
old_spec = BottleSpecification.new
|
2021-04-07 19:56:31 +01:00
|
|
|
old_catalina_sha256 = "109c0cb581a7b5d84da36d84b221fb9dd0f8a927b3044d82611791c9907e202e"
|
|
|
|
old_spec.sha256(catalina: old_catalina_sha256)
|
2021-02-01 16:14:25 -05:00
|
|
|
old_spec.sha256(mojave: "7571772bf7a0c9fe193e70e521318b53993bee6f351976c9b6e01e00d13d6c3f")
|
2021-04-07 19:56:31 +01:00
|
|
|
new_catalina_sha256 = "ec6d7f08412468f28dee2be17ad8cd8b883b16b34329efcecce019b8c9736428"
|
|
|
|
new_hash = { "tags" => { "catalina" => { "sha256" => new_catalina_sha256 } } }
|
2021-02-01 16:14:25 -05:00
|
|
|
expected_checksum_hash = { mojave: "7571772bf7a0c9fe193e70e521318b53993bee6f351976c9b6e01e00d13d6c3f" }
|
2021-04-08 01:56:05 +01:00
|
|
|
expected_checksum_hash[:cellar] = Homebrew::DEFAULT_MACOS_CELLAR
|
2021-02-01 16:14:25 -05:00
|
|
|
expect(homebrew.merge_bottle_spec([:sha256], old_spec, new_hash)).to eq [
|
2021-04-07 19:56:31 +01:00
|
|
|
["sha256 catalina: old: #{old_catalina_sha256.inspect}, new: #{new_catalina_sha256.inspect}"],
|
2021-02-01 16:14:25 -05:00
|
|
|
[expected_checksum_hash],
|
|
|
|
]
|
|
|
|
end
|
|
|
|
end
|
2020-12-09 23:02:31 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
describe "::generate_sha256_line" do
|
|
|
|
it "generates a string without cellar" do
|
2021-02-02 15:09:39 -05:00
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", nil, 0, 10)).to eq(
|
2021-02-01 16:14:25 -05:00
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "generates a string with cellar symbol" do
|
2021-02-02 15:09:39 -05:00
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", :any, 14, 24)).to eq(
|
2021-02-01 16:14:25 -05:00
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 cellar: :any, catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "generates a string with default cellar path" do
|
2021-02-02 15:09:39 -05:00
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", Homebrew::DEFAULT_LINUX_CELLAR, 0, 10)).to eq(
|
2021-02-01 16:14:25 -05:00
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
2020-12-09 23:02:31 +01:00
|
|
|
|
2021-02-01 16:14:25 -05:00
|
|
|
it "generates a string with non-default cellar path" do
|
2021-02-02 15:09:39 -05:00
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", "/home/test", 22, 32)).to eq(
|
2021-02-01 16:14:25 -05:00
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 cellar: "/home/test", catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
2020-12-25 13:10:10 -08:00
|
|
|
end
|
2021-02-02 15:09:39 -05:00
|
|
|
|
|
|
|
context "with offsets" do
|
|
|
|
it "generates a string without cellar" do
|
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", nil, 0, 15)).to eq(
|
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "generates a string with cellar symbol" do
|
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", :any, 20, 35)).to eq(
|
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 cellar: :any, catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "generates a string with default cellar path" do
|
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", Homebrew::DEFAULT_LINUX_CELLAR, 14, 30)).to eq(
|
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "generates a string with non-default cellar path" do
|
|
|
|
expect(homebrew.generate_sha256_line(:catalina, "deadbeef", "/home/test", 25, 36)).to eq(
|
|
|
|
<<~RUBY.chomp,
|
|
|
|
sha256 cellar: "/home/test", catalina: "deadbeef"
|
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
2021-02-01 16:14:25 -05:00
|
|
|
end
|
2021-04-28 12:00:14 -04:00
|
|
|
|
|
|
|
describe "::bottle_output" do
|
|
|
|
it "includes a custom root_url" do
|
|
|
|
bottle = BottleSpecification.new
|
|
|
|
bottle.root_url("https://example.com")
|
|
|
|
bottle.sha256(catalina: "109c0cb581a7b5d84da36d84b221fb9dd0f8a927b3044d82611791c9907e202e")
|
|
|
|
|
|
|
|
expect(homebrew.bottle_output(bottle, nil)).to eq(
|
2024-01-08 13:26:41 -08:00
|
|
|
<<-RUBY,
|
|
|
|
bottle do
|
|
|
|
root_url "https://example.com"
|
|
|
|
sha256 catalina: "109c0cb581a7b5d84da36d84b221fb9dd0f8a927b3044d82611791c9907e202e"
|
|
|
|
end
|
2021-04-28 12:00:14 -04:00
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "includes download strategy for custom root_url" do
|
|
|
|
bottle = BottleSpecification.new
|
|
|
|
bottle.root_url("https://example.com")
|
|
|
|
bottle.sha256(catalina: "109c0cb581a7b5d84da36d84b221fb9dd0f8a927b3044d82611791c9907e202e")
|
|
|
|
|
|
|
|
expect(homebrew.bottle_output(bottle, "ExampleStrategy")).to eq(
|
2024-01-08 13:26:41 -08:00
|
|
|
<<-RUBY,
|
|
|
|
bottle do
|
|
|
|
root_url "https://example.com",
|
|
|
|
using: ExampleStrategy
|
|
|
|
sha256 catalina: "109c0cb581a7b5d84da36d84b221fb9dd0f8a927b3044d82611791c9907e202e"
|
|
|
|
end
|
2021-04-28 12:00:14 -04:00
|
|
|
RUBY
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
2020-12-09 23:02:31 +01:00
|
|
|
end
|
|
|
|
end
|