2018-11-02 23:07:56 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
RSpec.describe "bundle install" do
|
|
|
|
context "installing a gem fails" do
|
2021-07-23 15:53:59 +02:00
|
|
|
it "prints out why that gem was being installed and the underlying error" do
|
2018-11-02 23:07:56 +00:00
|
|
|
build_repo2 do
|
|
|
|
build_gem "activesupport", "2.3.2" do |s|
|
|
|
|
s.extensions << "Rakefile"
|
|
|
|
s.write "Rakefile", <<-RUBY
|
|
|
|
task :default do
|
|
|
|
abort "make installing activesupport-2.3.2 fail"
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-06-03 18:43:17 +02:00
|
|
|
install_gemfile <<-G, :raise_on_error => false
|
2019-05-06 18:06:21 +02:00
|
|
|
source "#{file_uri_for(gem_repo2)}"
|
2018-11-02 23:07:56 +00:00
|
|
|
gem "rails"
|
|
|
|
G
|
2021-07-23 15:53:59 +02:00
|
|
|
expect(err).to start_with("Gem::Ext::BuildError: ERROR: Failed to build gem native extension.")
|
2019-05-06 18:06:21 +02:00
|
|
|
expect(err).to end_with(<<-M.strip)
|
2018-11-02 23:07:56 +00:00
|
|
|
An error occurred while installing activesupport (2.3.2), and Bundler cannot continue.
|
|
|
|
|
|
|
|
In Gemfile:
|
|
|
|
rails was resolved to 2.3.2, which depends on
|
|
|
|
actionmailer was resolved to 2.3.2, which depends on
|
|
|
|
activesupport
|
|
|
|
M
|
|
|
|
end
|
2019-04-14 06:01:35 +00:00
|
|
|
|
|
|
|
context "because the downloaded .gem was invalid" do
|
|
|
|
before do
|
|
|
|
build_repo4 do
|
|
|
|
build_gem "a"
|
|
|
|
end
|
|
|
|
|
|
|
|
gem_repo4("gems", "a-1.0.gem").open("w") {|f| f << "<html></html>" }
|
|
|
|
end
|
|
|
|
|
|
|
|
it "removes the downloaded .gem" do
|
2020-06-03 18:43:17 +02:00
|
|
|
install_gemfile <<-G, :raise_on_error => false
|
2019-05-06 18:06:21 +02:00
|
|
|
source "#{file_uri_for(gem_repo4)}"
|
2019-04-14 06:01:35 +00:00
|
|
|
gem "a"
|
|
|
|
G
|
|
|
|
|
|
|
|
expect(default_bundle_path("cache", "a-1.0.gem")).not_to exist
|
|
|
|
end
|
|
|
|
end
|
2018-11-02 23:07:56 +00:00
|
|
|
end
|
|
|
|
end
|