(#7076) Continue on if vagrant fails to parse metadata box for update

Prior to this commit, vagrant would halt if it could not parse the
metadata file for a box to check for updates with. This commit changes
that to behave like when vagrant fails to download a metadata file and
continue on but warn the user it failed to check for box updates.
This commit is contained in:
Brian Cain 2018-05-02 13:58:21 -07:00
parent b0cbac3da5
commit beb08b51a4
No known key found for this signature in database
GPG Key ID: 43D51080D357A001
3 changed files with 17 additions and 0 deletions

View File

@ -58,6 +58,9 @@ module Vagrant
env[:ui].warn(I18n.t(
"vagrant.box_outdated_metadata_download_error",
message: e.extra_data[:message]))
rescue Errors::BoxMetadataMalformed => e
@logger.warn(e.to_s)
env[:ui].warn(I18n.t("vagrant.box_malformed_continue_on_update"))
rescue Errors::VagrantError => e
raise if !env[:box_outdated_ignore_errors]
env[:ui].detail(I18n.t(

View File

@ -40,6 +40,9 @@ en:
URL: %{url}
box_loading_metadata: |-
Loading metadata for box '%{name}'
box_malformed_continue_on_update: |-
Could not determine box updates because box metadata was malformed.
Vagrant will continue on...
box_outdated: |-
* '%{name}' for '%{provider}' is outdated! Current: %{current}. Latest: %{latest}
box_outdated_checking_with_refresh: |-

View File

@ -166,6 +166,17 @@ describe Vagrant::Action::Builtin::BoxCheckOutdated do
expect(env[:box_outdated]).to be(false)
end
it "does nothing if metadata cannot be parsed" do
expect(box).to receive(:has_update?).and_raise(
Vagrant::Errors::BoxMetadataMalformed.new(error: "Whoopsie"))
expect(app).to receive(:call).once
subject.call(env)
expect(env[:box_outdated]).to be(false)
end
it "raises error if has_update? errors" do
expect(box).to receive(:has_update?).and_raise(Vagrant::Errors::VagrantError)