From 2bb2f9afe450b7507e07df66feb8a945f7884bee Mon Sep 17 00:00:00 2001 From: mo khan Date: Fri, 9 Apr 2021 13:31:08 -0600 Subject: [PATCH] fix(Go mod): detect when remote end hangs up --- .../go_modules/file_updater/go_mod_updater.rb | 1 + .../file_updater/go_mod_updater_spec.rb | 24 +++++++++++++++++++ 2 files changed, 25 insertions(+) diff --git a/go_modules/lib/dependabot/go_modules/file_updater/go_mod_updater.rb b/go_modules/lib/dependabot/go_modules/file_updater/go_mod_updater.rb index 87426eeb15..d1972d9732 100644 --- a/go_modules/lib/dependabot/go_modules/file_updater/go_mod_updater.rb +++ b/go_modules/lib/dependabot/go_modules/file_updater/go_mod_updater.rb @@ -21,6 +21,7 @@ class GoModUpdater ].freeze REPO_RESOLVABILITY_ERROR_REGEXES = [ + /fatal: The remote end hung up unexpectedly/, /repository '.+' not found/, # (Private) module could not be fetched /go: .*: git fetch .*: exit status 128/.freeze, diff --git a/go_modules/spec/dependabot/go_modules/file_updater/go_mod_updater_spec.rb b/go_modules/spec/dependabot/go_modules/file_updater/go_mod_updater_spec.rb index 1491aeb396..99d2ff3b86 100644 --- a/go_modules/spec/dependabot/go_modules/file_updater/go_mod_updater_spec.rb +++ b/go_modules/spec/dependabot/go_modules/file_updater/go_mod_updater_spec.rb @@ -283,6 +283,30 @@ end end + context "when the remote end hangs up unexpectedly" do + let(:dependency_name) { "github.com/spf13/viper" } + let(:dependency_version) { "v1.7.1" } + let(:dependency_previous_version) { "v1.7.1" } + let(:requirements) { [] } + let(:previous_requirements) { [] } + let(:exit_status) { double(status: 128, success?: false) } + let(:stderr) do + <<~ERROR + go: github.com/spf13/viper@v1.7.1 requires + github.com/grpc-ecosystem/grpc-gateway@v1.9.0 requires + gopkg.in/yaml.v2@v2.0.0-20170812160011-eb3733d160e7: invalid version: git fetch --unshallow -f origin in /opt/go/gopath/pkg/mod/cache/vcs/sha1: exit status 128: + fatal: The remote end hung up unexpectedly + ERROR + end + + before do + allow(Open3).to receive(:capture3).and_call_original + allow(Open3).to receive(:capture3).with(anything, "go get -d").and_return(["", stderr, exit_status]) + end + + it { expect { subject }.to raise_error(Dependabot::DependencyFileNotResolvable, /The remote end hung up/) } + end + context "for an explicit indirect dependency" do let(:project_name) { "indirect" } let(:dependency_name) { "github.com/mattn/go-isatty" }