2018-11-02 19:07:56 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-11-11 03:57:45 -05:00
|
|
|
require_relative "../support/silent_logger"
|
|
|
|
|
2018-11-02 19:07:56 -04:00
|
|
|
RSpec.describe "fetching dependencies with a not available mirror", :realworld => true do
|
|
|
|
let(:mirror) { @mirror_uri }
|
|
|
|
let(:original) { @server_uri }
|
|
|
|
let(:server_port) { @server_port }
|
|
|
|
let(:host) { "127.0.0.1" }
|
|
|
|
|
|
|
|
before do
|
|
|
|
require_rack
|
|
|
|
setup_server
|
|
|
|
setup_mirror
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Artifice.deactivate
|
|
|
|
@server_thread.kill
|
|
|
|
@server_thread.join
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with a specific fallback timeout" do
|
|
|
|
before do
|
|
|
|
global_config("BUNDLE_MIRROR__HTTP://127__0__0__1:#{server_port}/__FALLBACK_TIMEOUT/" => "true",
|
|
|
|
"BUNDLE_MIRROR__HTTP://127__0__0__1:#{server_port}/" => mirror)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "install a gem using the original uri when the mirror is not responding" do
|
|
|
|
gemfile <<-G
|
|
|
|
source "#{original}"
|
|
|
|
gem 'weakling'
|
|
|
|
G
|
|
|
|
|
|
|
|
bundle :install, :artifice => nil
|
|
|
|
|
|
|
|
expect(out).to include("Installing weakling")
|
|
|
|
expect(out).to include("Bundle complete")
|
|
|
|
expect(the_bundle).to include_gems "weakling 0.0.3"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with a global fallback timeout" do
|
|
|
|
before do
|
|
|
|
global_config("BUNDLE_MIRROR__ALL__FALLBACK_TIMEOUT/" => "1",
|
|
|
|
"BUNDLE_MIRROR__ALL" => mirror)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "install a gem using the original uri when the mirror is not responding" do
|
|
|
|
gemfile <<-G
|
|
|
|
source "#{original}"
|
|
|
|
gem 'weakling'
|
|
|
|
G
|
|
|
|
|
|
|
|
bundle :install, :artifice => nil
|
|
|
|
|
|
|
|
expect(out).to include("Installing weakling")
|
|
|
|
expect(out).to include("Bundle complete")
|
|
|
|
expect(the_bundle).to include_gems "weakling 0.0.3"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with a specific mirror without a fallback timeout" do
|
|
|
|
before do
|
|
|
|
global_config("BUNDLE_MIRROR__HTTP://127__0__0__1:#{server_port}/" => mirror)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "fails to install the gem with a timeout error" do
|
|
|
|
gemfile <<-G
|
|
|
|
source "#{original}"
|
|
|
|
gem 'weakling'
|
|
|
|
G
|
|
|
|
|
2020-06-03 12:43:17 -04:00
|
|
|
bundle :install, :artifice => nil, :raise_on_error => false
|
2018-11-02 19:07:56 -04:00
|
|
|
|
|
|
|
expect(out).to include("Fetching source index from #{mirror}")
|
2019-04-14 02:01:35 -04:00
|
|
|
expect(err).to include("Retrying fetcher due to error (2/4): Bundler::HTTPError Could not fetch specs from #{mirror}")
|
|
|
|
expect(err).to include("Retrying fetcher due to error (3/4): Bundler::HTTPError Could not fetch specs from #{mirror}")
|
|
|
|
expect(err).to include("Retrying fetcher due to error (4/4): Bundler::HTTPError Could not fetch specs from #{mirror}")
|
|
|
|
expect(err).to include("Could not fetch specs from #{mirror}")
|
2018-11-02 19:07:56 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "prints each error and warning on a new line" do
|
|
|
|
gemfile <<-G
|
|
|
|
source "#{original}"
|
|
|
|
gem 'weakling'
|
|
|
|
G
|
|
|
|
|
2020-06-03 12:43:17 -04:00
|
|
|
bundle :install, :artifice => nil, :raise_on_error => false
|
2018-11-02 19:07:56 -04:00
|
|
|
|
2019-06-01 05:49:40 -04:00
|
|
|
expect(out).to include "Fetching source index from #{mirror}/"
|
|
|
|
expect(err).to include <<-EOS.strip
|
2018-11-02 19:07:56 -04:00
|
|
|
Retrying fetcher due to error (2/4): Bundler::HTTPError Could not fetch specs from #{mirror}/
|
|
|
|
Retrying fetcher due to error (3/4): Bundler::HTTPError Could not fetch specs from #{mirror}/
|
|
|
|
Retrying fetcher due to error (4/4): Bundler::HTTPError Could not fetch specs from #{mirror}/
|
|
|
|
Could not fetch specs from #{mirror}/
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with a global mirror without a fallback timeout" do
|
|
|
|
before do
|
|
|
|
global_config("BUNDLE_MIRROR__ALL" => mirror)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "fails to install the gem with a timeout error" do
|
|
|
|
gemfile <<-G
|
|
|
|
source "#{original}"
|
|
|
|
gem 'weakling'
|
|
|
|
G
|
|
|
|
|
2020-06-03 12:43:17 -04:00
|
|
|
bundle :install, :artifice => nil, :raise_on_error => false
|
2018-11-02 19:07:56 -04:00
|
|
|
|
|
|
|
expect(out).to include("Fetching source index from #{mirror}")
|
2019-04-14 02:01:35 -04:00
|
|
|
expect(err).to include("Retrying fetcher due to error (2/4): Bundler::HTTPError Could not fetch specs from #{mirror}")
|
|
|
|
expect(err).to include("Retrying fetcher due to error (3/4): Bundler::HTTPError Could not fetch specs from #{mirror}")
|
|
|
|
expect(err).to include("Retrying fetcher due to error (4/4): Bundler::HTTPError Could not fetch specs from #{mirror}")
|
|
|
|
expect(err).to include("Could not fetch specs from #{mirror}")
|
2018-11-02 19:07:56 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def setup_server
|
|
|
|
@server_port = find_unused_port
|
|
|
|
@server_uri = "http://#{host}:#{@server_port}"
|
|
|
|
|
2019-11-11 03:57:45 -05:00
|
|
|
require_relative "../support/artifice/endpoint"
|
2018-11-02 19:07:56 -04:00
|
|
|
|
|
|
|
@server_thread = Thread.new do
|
|
|
|
Rack::Server.start(:app => Endpoint,
|
|
|
|
:Host => host,
|
|
|
|
:Port => @server_port,
|
|
|
|
:server => "webrick",
|
|
|
|
:AccessLog => [],
|
|
|
|
:Logger => Spec::SilentLogger.new)
|
|
|
|
end.run
|
|
|
|
|
|
|
|
wait_for_server(host, @server_port)
|
|
|
|
end
|
|
|
|
|
|
|
|
def setup_mirror
|
|
|
|
mirror_port = find_unused_port
|
|
|
|
@mirror_uri = "http://#{host}:#{mirror_port}"
|
|
|
|
end
|
|
|
|
end
|