From e0621c159e95efdcd3b04e99dab9375d378496da Mon Sep 17 00:00:00 2001 From: Mike McQuaid Date: Wed, 13 Dec 2023 16:40:37 +0000 Subject: [PATCH] tap_dumper: filter HOMEBREW_GITHUB_API_TOKEN. If it's present in a tap's git remote: filter it out and replace it with a lookup for the environment variable instead. --- lib/bundle/tap_dumper.rb | 8 ++++++++ spec/bundle/tap_dumper_spec.rb | 27 +++++++++++++++++++++------ 2 files changed, 29 insertions(+), 6 deletions(-) diff --git a/lib/bundle/tap_dumper.rb b/lib/bundle/tap_dumper.rb index 98a47a3fb..3fff071f9 100644 --- a/lib/bundle/tap_dumper.rb +++ b/lib/bundle/tap_dumper.rb @@ -13,6 +13,14 @@ def reset! def dump taps.map do |tap| remote = if tap.custom_remote? && (tap_remote = tap.remote) + if (api_token = ENV.fetch("HOMEBREW_GITHUB_API_TOKEN", false).presence) + # Replace the API token in the remote URL with interpolation. + # Rubocop's warning here is wrong; we intentionally want to not + # evaluate this string until the Brewfile is evaluated. + # rubocop:disable Lint/InterpolationCheck + tap_remote = tap_remote.gsub api_token, '#{ENV.fetch("HOMEBREW_GITHUB_API_TOKEN")}' + # rubocop:enable Lint/InterpolationCheck + end ", \"#{tap_remote}\"" end "tap \"#{tap.name}\"#{remote}" diff --git a/spec/bundle/tap_dumper_spec.rb b/spec/bundle/tap_dumper_spec.rb index a22c1dbe2..a9f1271d6 100644 --- a/spec/bundle/tap_dumper_spec.rb +++ b/spec/bundle/tap_dumper_spec.rb @@ -19,14 +19,26 @@ end end - context "with `bitbucket/bar`, `homebrew/baz` and `homebrew/foo` taps" do + context "with taps" do before do described_class.reset! + bar = instance_double(Tap, name: "bitbucket/bar", custom_remote?: true, remote: "https://bitbucket.org/bitbucket/bar.git") baz = instance_double(Tap, name: "homebrew/baz", custom_remote?: false) foo = instance_double(Tap, name: "homebrew/foo", custom_remote?: false) - allow(Tap).to receive(:each).and_return [bar, baz, foo] + + ENV["HOMEBREW_GITHUB_API_TOKEN_BEFORE"] = ENV.fetch("HOMEBREW_GITHUB_API_TOKEN", nil) + ENV["HOMEBREW_GITHUB_API_TOKEN"] = "some-token" + private_tap = instance_double(Tap, name: "privatebrew/private", custom_remote?: true, + remote: "https://#{ENV.fetch("HOMEBREW_GITHUB_API_TOKEN")}@github.com/privatebrew/homebrew-private") + + allow(Tap).to receive(:each).and_return [bar, baz, foo, private_tap] + end + + after do + ENV["HOMEBREW_GITHUB_API_TOKEN"] = ENV.fetch("HOMEBREW_GITHUB_API_TOKEN_BEFORE", nil) + ENV.delete("HOMEBREW_GITHUB_API_TOKEN_BEFORE") end it "returns list of information" do @@ -34,10 +46,13 @@ end it "dumps output" do - expect(dumper.dump).to eql( - "tap \"bitbucket/bar\", \"https://bitbucket.org/bitbucket/bar.git\"\n" \ - "tap \"homebrew/baz\"\ntap \"homebrew/foo\"", - ) + expected_output = <<~EOS + tap "bitbucket/bar", "https://bitbucket.org/bitbucket/bar.git" + tap "homebrew/baz" + tap "homebrew/foo" + tap "privatebrew/private", "https://\#{ENV.fetch("HOMEBREW_GITHUB_API_TOKEN")}@github.com/privatebrew/homebrew-private" + EOS + expect(dumper.dump).to eql(expected_output.chomp) end end end