diff options
author | Keith Shook <keith.shook@ontariosystems.com> | 2015-01-27 11:06:05 -0500 |
---|---|---|
committer | Keith Shook <keith.shook@ontariosystems.com> | 2015-01-27 11:06:05 -0500 |
commit | b65bd90f034d101c32683a9c2919ee600935b071 (patch) | |
tree | 1577844e5adc2b08169afb9c2f3717fd44d48ffd /spec/support | |
parent | f92d08849078eee5411e0678d43d06f67cdbac2d (diff) | |
download | bundler-b65bd90f034d101c32683a9c2919ee600935b071.tar.gz |
Added test to expose a scenario with API sources where dependencies fail to resolve when then shouldn't
Diffstat (limited to 'spec/support')
-rw-r--r-- | spec/support/artifice/endpoint.rb | 10 | ||||
-rw-r--r-- | spec/support/artifice/endpoint_extra_api.rb | 32 | ||||
-rw-r--r-- | spec/support/builders.rb | 6 | ||||
-rw-r--r-- | spec/support/path.rb | 4 |
4 files changed, 47 insertions, 5 deletions
diff --git a/spec/support/artifice/endpoint.rb b/spec/support/artifice/endpoint.rb index 68b41b7528..adff4a7bcd 100644 --- a/spec/support/artifice/endpoint.rb +++ b/spec/support/artifice/endpoint.rb @@ -14,14 +14,14 @@ require 'sinatra/base' class Endpoint < Sinatra::Base helpers do - def dependencies_for(gem_names, marshal = gem_repo1("specs.4.8")) + def dependencies_for(gem_names, gem_repo = gem_repo1) return [] if gem_names.nil? || gem_names.empty? require 'rubygems' require 'bundler' Bundler::Deprecate.skip_during do - Marshal.load(File.open(marshal).read).map do |name, version, platform| - spec = load_spec(name, version, platform) + Marshal.load(File.open(gem_repo.join("specs.4.8")).read).map do |name, version, platform| + spec = load_spec(name, version, platform, gem_repo) if gem_names.include?(spec.name) { :name => spec.name, @@ -36,10 +36,10 @@ class Endpoint < Sinatra::Base end end - def load_spec(name, version, platform) + def load_spec(name, version, platform, gem_repo) full_name = "#{name}-#{version}" full_name += "-#{platform}" if platform != "ruby" - Marshal.load(Gem.inflate(File.open(gem_repo1("quick/Marshal.4.8/#{full_name}.gemspec.rz")).read)) + Marshal.load(Gem.inflate(File.open(gem_repo.join("quick/Marshal.4.8/#{full_name}.gemspec.rz")).read)) end end diff --git a/spec/support/artifice/endpoint_extra_api.rb b/spec/support/artifice/endpoint_extra_api.rb new file mode 100644 index 0000000000..d6d1c5a1b4 --- /dev/null +++ b/spec/support/artifice/endpoint_extra_api.rb @@ -0,0 +1,32 @@ +require File.expand_path("../endpoint", __FILE__) + +Artifice.deactivate + +class EndpointExtraApi < Endpoint + get "/extra/api/v1/dependencies" do + deps = dependencies_for(params[:gems], gem_repo4) + Marshal.dump(deps) + end + + get "/extra/specs.4.8.gz" do + File.read("#{gem_repo4}/specs.4.8.gz") + end + + get "/extra/prerelease_specs.4.8.gz" do + File.read("#{gem_repo4}/prerelease_specs.4.8.gz") + end + + get "/extra/quick/Marshal.4.8/:id" do + redirect "/extra/fetch/actual/gem/#{params[:id]}" + end + + get "/extra/fetch/actual/gem/:id" do + File.read("#{gem_repo4}/quick/Marshal.4.8/#{params[:id]}") + end + + get "/extra/gems/:id" do + File.read("#{gem_repo4}/gems/#{params[:id]}") + end +end + +Artifice.activate_with(EndpointExtraApi) diff --git a/spec/support/builders.rb b/spec/support/builders.rb index 896228d161..9b5d445e90 100644 --- a/spec/support/builders.rb +++ b/spec/support/builders.rb @@ -260,6 +260,12 @@ module Spec FileUtils.rm_rf Dir[gem_repo3("prerelease*")] end + # A repo that has no pre-installed gems included. (The caller completely determines the contents with the block) + def build_repo4(&blk) + FileUtils.rm_rf gem_repo4 + build_repo(gem_repo4, &blk) + end + def update_repo2 update_repo gem_repo2 do build_gem "rack", "1.2" do |s| diff --git a/spec/support/path.rb b/spec/support/path.rb index 74dbd891a5..56e8dd8b41 100644 --- a/spec/support/path.rb +++ b/spec/support/path.rb @@ -60,6 +60,10 @@ module Spec tmp("gems/remote3", *args) end + def gem_repo4(*args) + tmp("gems/remote4", *args) + end + def security_repo(*args) tmp("gems/security_repo", *args) end |