| 
									
										
										
										
											2019-04-19 15:38:03 +09:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | require "cmd/update-report" | 
					
						
							|  |  |  | require "formula_versions" | 
					
						
							|  |  |  | require "yaml" | 
					
						
							| 
									
										
										
										
											2019-03-28 08:35:36 +00:00
										 |  |  | require "cmd/shared_examples/args_parse" | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-01 11:55:05 -07:00
										 |  |  | RSpec.describe Homebrew::Cmd::UpdateReport do | 
					
						
							| 
									
										
										
										
											2019-03-28 08:35:36 +00:00
										 |  |  |   it_behaves_like "parseable arguments" | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |   describe Reporter do | 
					
						
							| 
									
										
										
										
											2024-03-06 15:10:14 +01:00
										 |  |  |     let(:tap) { CoreTap.instance } | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     let(:reporter_class) do | 
					
						
							|  |  |  |       Class.new(described_class) do | 
					
						
							|  |  |  |         def initialize(tap) | 
					
						
							|  |  |  |           @tap = tap | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-24 10:15:34 +01:00
										 |  |  |           ENV["HOMEBREW_UPDATE_BEFORE#{tap.repository_var_suffix}"] = "12345678" | 
					
						
							|  |  |  |           ENV["HOMEBREW_UPDATE_AFTER#{tap.repository_var_suffix}"] = "abcdef00" | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-23 17:08:41 +01:00
										 |  |  |           super | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     let(:reporter) { reporter_class.new(tap) } | 
					
						
							|  |  |  |     let(:hub) { ReporterHub.new } | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     def perform_update(fixture_name = "") | 
					
						
							| 
									
										
										
										
											2023-01-22 17:05:16 -08:00
										 |  |  |       allow(Formulary).to receive(:factory).and_return(instance_double(Formula, pkg_version: "1.0")) | 
					
						
							|  |  |  |       allow(FormulaVersions).to receive(:new).and_return(instance_double(FormulaVersions, formula_at_revision: "2.0")) | 
					
						
							| 
									
										
										
										
											2019-03-28 08:35:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       diff = YAML.load_file("#{TEST_FIXTURE_DIR}/updater_fixture.yaml")[fixture_name] | 
					
						
							|  |  |  |       allow(reporter).to receive(:diff).and_return(diff || "") | 
					
						
							| 
									
										
										
										
											2019-03-28 08:35:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       hub.add(reporter) if reporter.updated? | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2019-03-28 08:35:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "without revision variable" do | 
					
						
							|  |  |  |       ENV.delete_if { |k, _v| k.start_with? "HOMEBREW_UPDATE" } | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-08 23:14:46 +00:00
										 |  |  |       expect do | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |         described_class.new(tap) | 
					
						
							| 
									
										
										
										
											2023-03-08 23:14:46 +00:00
										 |  |  |       end.to raise_error(Reporter::ReporterRevisionUnsetError) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "without any changes" do | 
					
						
							|  |  |  |       perform_update | 
					
						
							|  |  |  |       expect(hub).to be_empty | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "without Formula changes" do | 
					
						
							|  |  |  |       perform_update("update_git_diff_output_without_formulae_changes") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |       expect(hub.select_formula_or_cask(:M)).to be_empty | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:A)).to be_empty | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:D)).to be_empty | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "with Formula changes" do | 
					
						
							|  |  |  |       perform_update("update_git_diff_output_with_formulae_changes") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |       expect(hub.select_formula_or_cask(:M)).to eq(%w[xar yajl]) | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:A)).to eq(%w[antiword bash-completion ddrescue dict lua]) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "with removed Formulae" do | 
					
						
							|  |  |  |       perform_update("update_git_diff_output_with_removed_formulae") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |       expect(hub.select_formula_or_cask(:D)).to eq(%w[libgsasl]) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "with changed file type" do | 
					
						
							|  |  |  |       perform_update("update_git_diff_output_with_changed_filetype") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |       expect(hub.select_formula_or_cask(:M)).to eq(%w[elixir]) | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:A)).to eq(%w[libbson]) | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:D)).to eq(%w[libgsasl]) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     specify "with renamed Formula" do | 
					
						
							|  |  |  |       allow(tap).to receive(:formula_renames).and_return("cv" => "progress") | 
					
						
							|  |  |  |       perform_update("update_git_diff_output_with_formula_rename") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |       expect(hub.select_formula_or_cask(:A)).to be_empty | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:D)).to be_empty | 
					
						
							|  |  |  |       expect(hub.select_formula_or_cask(:R)).to eq([["cv", "progress"]]) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |     context "when updating a Tap other than the core Tap" do | 
					
						
							| 
									
										
										
										
											2024-03-06 15:10:14 +01:00
										 |  |  |       let(:tap) { Tap.fetch("foo", "bar") } | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       before do | 
					
						
							|  |  |  |         (tap.path/"Formula").mkpath | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       after do | 
					
						
							| 
									
										
										
										
											2024-09-24 10:15:34 +01:00
										 |  |  |         FileUtils.rm_r(tap.path.parent) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       specify "with restructured Tap" do | 
					
						
							|  |  |  |         perform_update("update_git_diff_output_with_restructured_tap") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |         expect(hub.select_formula_or_cask(:A)).to be_empty | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:D)).to be_empty | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:R)).to be_empty | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       specify "with renamed Formula and restructured Tap" do | 
					
						
							|  |  |  |         allow(tap).to receive(:formula_renames).and_return("xchat" => "xchat2") | 
					
						
							|  |  |  |         perform_update("update_git_diff_output_with_formula_rename_and_restructuring") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |         expect(hub.select_formula_or_cask(:A)).to be_empty | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:D)).to be_empty | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:R)).to eq([%w[foo/bar/xchat foo/bar/xchat2]]) | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       specify "with simulated 'homebrew/php' restructuring" do | 
					
						
							|  |  |  |         perform_update("update_git_diff_simulate_homebrew_php_restructuring") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |         expect(hub.select_formula_or_cask(:A)).to be_empty | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:D)).to be_empty | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:R)).to be_empty | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       specify "with Formula changes" do | 
					
						
							|  |  |  |         perform_update("update_git_diff_output_with_tap_formulae_changes") | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-03 19:16:15 +01:00
										 |  |  |         expect(hub.select_formula_or_cask(:A)).to eq(%w[foo/bar/lua]) | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:M)).to eq(%w[foo/bar/git]) | 
					
						
							|  |  |  |         expect(hub.select_formula_or_cask(:D)).to be_empty | 
					
						
							| 
									
										
										
										
											2021-02-01 16:14:25 -05:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2025-06-24 16:59:24 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe ReporterHub do | 
					
						
							|  |  |  |     let(:hub) { described_class.new } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     before do | 
					
						
							|  |  |  |       ENV["HOMEBREW_NO_COLOR"] = "1" | 
					
						
							|  |  |  |       allow(hub).to receive(:select_formula_or_cask).and_return([]) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "dumps new formulae report" do | 
					
						
							|  |  |  |       allow(hub).to receive(:select_formula_or_cask).with(:A).and_return(["foo", "bar", "baz"]) | 
					
						
							|  |  |  |       allow(hub).to receive_messages(installed?: false, all_formula_json: [ | 
					
						
							|  |  |  |         { "name" => "foo", "desc" => "foobly things" }, | 
					
						
							|  |  |  |         { "name" => "baz", "desc" => "baz desc" }, | 
					
						
							|  |  |  |       ]) | 
					
						
							|  |  |  |       expect { hub.dump }.to output(<<~EOS).to_stdout | 
					
						
							|  |  |  |         ==> New Formulae | 
					
						
							|  |  |  |         bar | 
					
						
							|  |  |  |         baz: baz desc | 
					
						
							|  |  |  |         foo: foobly things | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "dumps new casks report" do | 
					
						
							|  |  |  |       allow(hub).to receive(:select_formula_or_cask).with(:AC).and_return(["foo/cask1", "foo/cask2", "foo/cask3"]) | 
					
						
							|  |  |  |       allow(hub).to receive_messages(cask_installed?: false, all_cask_json: [ | 
					
						
							|  |  |  |         { "token" => "cask1", "desc" => "desc1" }, | 
					
						
							|  |  |  |         { "token" => "cask3", "desc" => "desc3" }, | 
					
						
							|  |  |  |       ]) | 
					
						
							|  |  |  |       allow(Cask::Caskroom).to receive(:any_casks_installed?).and_return(true) | 
					
						
							|  |  |  |       expect { hub.dump }.to output(<<~EOS).to_stdout | 
					
						
							|  |  |  |         ==> New Casks | 
					
						
							|  |  |  |         cask1: desc1 | 
					
						
							|  |  |  |         cask2 | 
					
						
							|  |  |  |         cask3: desc3 | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "dumps deleted installed formulae and casks report" do | 
					
						
							|  |  |  |       allow(hub).to receive(:select_formula_or_cask).with(:D).and_return(["baz", "foo", "bar"]) | 
					
						
							|  |  |  |       allow(hub).to receive(:installed?).with("baz").and_return(true) | 
					
						
							|  |  |  |       allow(hub).to receive(:installed?).with("foo").and_return(true) | 
					
						
							|  |  |  |       allow(hub).to receive(:installed?).with("bar").and_return(true) | 
					
						
							|  |  |  |       allow(hub).to receive(:select_formula_or_cask).with(:A).and_return([]) | 
					
						
							|  |  |  |       allow(hub).to receive(:select_formula_or_cask).with(:DC).and_return(["cask2", "cask1"]) | 
					
						
							|  |  |  |       allow(hub).to receive(:cask_installed?).with("cask1").and_return(true) | 
					
						
							|  |  |  |       allow(hub).to receive(:cask_installed?).with("cask2").and_return(true) | 
					
						
							|  |  |  |       allow(Homebrew::SimulateSystem).to receive(:simulating_or_running_on_linux?).and_return(false) | 
					
						
							|  |  |  |       expect { hub.dump }.to output(<<~EOS).to_stdout | 
					
						
							|  |  |  |         ==> Deleted Installed Formulae | 
					
						
							|  |  |  |         bar | 
					
						
							|  |  |  |         baz | 
					
						
							|  |  |  |         foo | 
					
						
							|  |  |  |         ==> Deleted Installed Casks | 
					
						
							|  |  |  |         cask1 | 
					
						
							|  |  |  |         cask2 | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "dumps outdated formulae and casks report" do | 
					
						
							|  |  |  |       allow(Formula).to receive(:installed).and_return([ | 
					
						
							|  |  |  |         instance_double(Formula, name: "foo", outdated?: true), | 
					
						
							|  |  |  |         instance_double(Formula, name: "bar", outdated?: true), | 
					
						
							|  |  |  |       ]) | 
					
						
							|  |  |  |       allow(Cask::Caskroom).to receive(:casks).and_return([ | 
					
						
							|  |  |  |         instance_double(Cask::Cask, token: "baz", outdated?: true), | 
					
						
							|  |  |  |         instance_double(Cask::Cask, token: "qux", outdated?: true), | 
					
						
							|  |  |  |       ]) | 
					
						
							|  |  |  |       expect { hub.dump }.to output(<<~EOS).to_stdout | 
					
						
							|  |  |  |         ==> Outdated Formulae | 
					
						
							|  |  |  |         bar | 
					
						
							|  |  |  |         foo | 
					
						
							|  |  |  |         ==> Outdated Casks | 
					
						
							|  |  |  |         baz | 
					
						
							|  |  |  |         qux | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         You have 2 outdated formulae and 2 outdated casks installed. | 
					
						
							|  |  |  |         You can upgrade them with brew upgrade | 
					
						
							|  |  |  |         or list them with brew outdated. | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it "prints nothing if there are no changes" do | 
					
						
							|  |  |  |       allow(Formula).to receive(:installed).and_return([]) | 
					
						
							|  |  |  |       allow(Cask::Caskroom).to receive(:casks).and_return([]) | 
					
						
							|  |  |  |       expect { hub.dump }.not_to output.to_stdout | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-08-05 18:23:08 +02:00
										 |  |  | end |