Skip to content
This repository has been archived by the owner on Apr 14, 2021. It is now read-only.

Commit

Permalink
Merge #7547
Browse files Browse the repository at this point in the history
7547: Release 2.1.4 r=deivid-rodriguez a=deivid-rodriguez

This PR gets out there two more bug fixes in the 2.1 line. Specifically #7529 and #7537.

Co-authored-by: Bundlerbot <[email protected]>
Co-authored-by: David Rodríguez <[email protected]>
  • Loading branch information
bundlerbot and deivid-rodriguez committed Jan 5, 2020
2 parents 14c5584 + f73e11e commit 32a4159
Show file tree
Hide file tree
Showing 12 changed files with 74 additions and 45 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
## 2.1.4 (January 5, 2020)

Bugfixes:

- Fix `net-http-pipeline` no longer being allowed in Gemfiles if already installed in the system due to our vendored version of `net-http-persistent` optionally requiring it [#7529](https://github.com/bundler/bundler/pull/7529)
- Fix inline gems no longer being requirable if no Gemfile is present in the directory hierarchy [#7537](https://github.com/bundler/bundler/pull/7537)

## 2.1.3 (January 2, 2020)

Bugfixes:
Expand Down
2 changes: 1 addition & 1 deletion lib/bundler/inline.rb
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ def definition.lock(*); end
if old_gemfile
ENV["BUNDLE_GEMFILE"] = old_gemfile
else
ENV.delete("BUNDLE_GEMFILE")
ENV["BUNDLE_GEMFILE"] = ""
end
end
end
22 changes: 0 additions & 22 deletions lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,6 @@
require 'cgi' # for escaping
require_relative '../../../../connection_pool/lib/connection_pool'

begin
require 'net/http/pipeline'
rescue LoadError
end

autoload :OpenSSL, 'openssl'

##
Expand Down Expand Up @@ -773,23 +768,6 @@ def normalize_uri uri
(uri =~ /^https?:/) ? uri : "http://#{uri}"
end

##
# Pipelines +requests+ to the HTTP server at +uri+ yielding responses if a
# block is given. Returns all responses received.
#
# See
# Net::HTTP::Pipeline[http://docs.seattlerb.org/net-http-pipeline/Net/HTTP/Pipeline.html]
# for further details.
#
# Only if <tt>net-http-pipeline</tt> was required before
# <tt>net-http-persistent</tt> #pipeline will be present.

def pipeline uri, requests, &block # :yields: responses
connection_for uri do |connection|
connection.http.pipeline requests, &block
end
end

##
# Sets this client's SSL private key

Expand Down
2 changes: 1 addition & 1 deletion lib/bundler/version.rb
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# frozen_string_literal: false

module Bundler
VERSION = "2.1.3".freeze
VERSION = "2.1.4".freeze

def self.bundler_major_version
@bundler_major_version ||= VERSION.split(".").first.to_i
Expand Down
2 changes: 1 addition & 1 deletion spec/commands/pristine_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@

it "reinstall gemspec dependency" do
spec = Bundler.definition.specs["baz-dev"].first
changed_file = Pathname.new(spec.full_gem_path).join("lib/baz-dev.rb")
changed_file = Pathname.new(spec.full_gem_path).join("lib/baz/dev.rb")
diff = "#Pristine spec changes"

File.open(changed_file, "a") {|f| f.puts "#Pristine spec changes" }
Expand Down
2 changes: 1 addition & 1 deletion spec/install/gemfile/gemspec_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -210,7 +210,7 @@
build_lib("foo", :path => bundled_app)
gemspec = bundled_app("foo.gemspec").read
bundled_app("foo.gemspec").open("w") do |f|
f.write "#{gemspec.strip}.tap { gem 'rack-obama'; require 'rack-obama' }"
f.write "#{gemspec.strip}.tap { gem 'rack-obama'; require 'rack/obama' }"
end

install_gemfile! <<-G
Expand Down
10 changes: 5 additions & 5 deletions spec/plugins/source/example_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -125,14 +125,14 @@ def install(spec, opts)
end

it "installs the gem executables" do
build_lib "gem-with-bin" do |s|
build_lib "gem_with_bin" do |s|
s.executables = ["foo"]
end

install_gemfile <<-G
source "#{file_uri_for(gem_repo2)}" # plugin source
source "#{lib_path("gem-with-bin-1.0")}", :type => :mpath do
gem "gem-with-bin"
source "#{lib_path("gem_with_bin-1.0")}", :type => :mpath do
gem "gem_with_bin"
end
G

Expand Down Expand Up @@ -451,7 +451,7 @@ def installed?
bundle "install"

run <<-RUBY
require 'ma-gitp-gem'
require 'ma/gitp/gem'
puts "WIN" unless defined?(MAGITPGEM_PREV_REF)
RUBY
expect(out).to eq("WIN")
Expand All @@ -462,7 +462,7 @@ def installed?
bundle "update ma-gitp-gem"

run <<-RUBY
require 'ma-gitp-gem'
require 'ma/gitp/gem'
puts "WIN" if defined?(MAGITPGEM_PREV_REF)
RUBY
expect(out).to eq("WIN")
Expand Down
17 changes: 17 additions & 0 deletions spec/runtime/inline_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -333,4 +333,21 @@ def confirm(msg, newline = nil)
expect(last_command).to be_success
expect(out).to include("BUNDLE_GEMFILE is empty")
end

it "resets BUNDLE_GEMFILE to the empty string if it wasn't set previously" do
ENV["BUNDLE_GEMFILE"] = nil
script <<-RUBY
gemfile do
source "#{file_uri_for(gem_repo1)}"
gem "rack"
end
puts "BUNDLE_GEMFILE is empty" if ENV["BUNDLE_GEMFILE"].empty?
system("#{Gem.ruby} -w -e '42'") # this should see original value of BUNDLE_GEMFILE
exit $?.exitstatus
RUBY

expect(last_command).to be_success
expect(out).to include("BUNDLE_GEMFILE is empty")
end
end
2 changes: 0 additions & 2 deletions spec/runtime/require_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,6 @@
build_lib "jquery-rails", "1.0.0" do |s|
s.write "lib/jquery/rails.rb", "puts 'jquery/rails'"
end
lib_path("jquery-rails-1.0.0/lib/jquery-rails.rb").rmtree
end

it "requires gem names that are namespaced" do
Expand Down Expand Up @@ -241,7 +240,6 @@
build_lib "load-fuuu", "1.0.0" do |s|
s.write "lib/load/fuuu.rb", "raise LoadError.new(\"cannot load such file -- load-bar\")"
end
lib_path("load-fuuu-1.0.0/lib/load-fuuu.rb").rmtree

gemfile <<-G
path "#{lib_path}" do
Expand Down
29 changes: 25 additions & 4 deletions spec/runtime/setup_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -899,17 +899,17 @@ def clean_load_path(lp)

describe "with git gems that don't have gemspecs" do
before :each do
build_git "no-gemspec", :gemspec => false
build_git "no_gemspec", :gemspec => false

install_gemfile <<-G
gem "no-gemspec", "1.0", :git => "#{lib_path("no-gemspec-1.0")}"
gem "no_gemspec", "1.0", :git => "#{lib_path("no_gemspec-1.0")}"
G
end

it "loads the library via a virtual spec" do
run <<-R
require 'no-gemspec'
puts NOGEMSPEC
require 'no_gemspec'
puts NO_GEMSPEC
R

expect(out).to eq("1.0")
Expand Down Expand Up @@ -1263,6 +1263,27 @@ def lock_with(ruby_version = nil)
expect(out).to eq("{}")
end

it "does not load net-http-pipeline too early" do
build_repo4 do
build_gem "net-http-pipeline", "1.0.1"
end

system_gems "net-http-pipeline-1.0.1", :gem_repo => gem_repo4 do
gemfile <<-G
source "#{file_uri_for(gem_repo4)}"
gem "net-http-pipeline", "1.0.1"
G

bundle "config set --local path vendor/bundle"

bundle! :install

bundle! :check

expect(out).to eq("The Gemfile's dependencies are satisfied")
end
end

Gem::Specification.select(&:default_gem?).map(&:name).each do |g|
it "activates newer versions of #{g}" do
skip if exemptions.include?(g)
Expand Down
20 changes: 14 additions & 6 deletions spec/support/builders.rb
Original file line number Diff line number Diff line change
Expand Up @@ -611,7 +611,7 @@ def @spec.validate(*); end
unless options[:no_default]
gem_source = options[:source] || "path@#{path}"
@files = _default_files.
merge("lib/#{name}/source.rb" => "#{Builders.constantize(name)}_SOURCE = #{gem_source.to_s.dump}").
merge("lib/#{entrypoint}/source.rb" => "#{Builders.constantize(name)}_SOURCE = #{gem_source.to_s.dump}").
merge(@files)
end

Expand All @@ -627,15 +627,20 @@ def @spec.validate(*); end
end

def _default_files
@_default_files ||= begin
platform_string = " #{@spec.platform}" unless @spec.platform == Gem::Platform::RUBY
{ "lib/#{name}.rb" => "#{Builders.constantize(name)} = '#{version}#{platform_string}'" }
end
@_default_files ||= { "lib/#{entrypoint}.rb" => "#{Builders.constantize(name)} = '#{version}#{platform_string}'" }
end

def entrypoint
name.tr("-", "/")
end

def _default_path
@context.tmp("libs", @spec.full_name)
end

def platform_string
" #{@spec.platform}" unless @spec.platform == Gem::Platform::RUBY
end
end

class GitBuilder < LibBuilder
Expand Down Expand Up @@ -755,7 +760,10 @@ def _default_path

class PluginBuilder < GemBuilder
def _default_files
@_default_files ||= super.merge("plugins.rb" => "")
@_default_files ||= {
"lib/#{name}.rb" => "#{Builders.constantize(name)} = '#{version}#{platform_string}'",
"plugins.rb" => "",
}
end
end

Expand Down
4 changes: 2 additions & 2 deletions spec/support/matchers.rb
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ def indent(string, padding = 4, indent_character = " ")
groups << opts
@errors = names.map do |name|
name, version, platform = name.split(/\s+/)
require_path = name == "bundler" ? "#{lib_dir}/bundler" : name
require_path = name == "bundler" ? "#{lib_dir}/bundler" : name.tr("-", "/")
version_const = name == "bundler" ? "Bundler::VERSION" : Spec::Builders.constantize(name)
begin
run! "require '#{require_path}.rb'; puts #{version_const}", *groups
Expand All @@ -145,7 +145,7 @@ def indent(string, padding = 4, indent_character = " ")
next unless source
begin
source_const = "#{Spec::Builders.constantize(name)}_SOURCE"
run! "require '#{name}/source'; puts #{source_const}", *groups
run! "require '#{require_path}/source'; puts #{source_const}", *groups
rescue StandardError
next "#{name} does not have a source defined:\n#{indent(e)}"
end
Expand Down

0 comments on commit 32a4159

Please sign in to comment.