Skip to content

Commit

Permalink
Prevent passing version to bin/bundle
Browse files Browse the repository at this point in the history
  • Loading branch information
vinistock committed Oct 23, 2024
1 parent 9dfbadd commit c00b6c8
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 5 deletions.
2 changes: 1 addition & 1 deletion exe/ruby-lsp
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ if ENV["BUNDLE_GEMFILE"].nil?
"bundle"
end

exit exec(env, "#{base_bundle} exec ruby-lsp #{original_args.join(" ")}")
exit exec(env, "#{base_bundle} exec ruby-lsp #{original_args.join(" ")}".strip)
end

require "ruby_lsp/load_sorbet"
Expand Down
15 changes: 14 additions & 1 deletion lib/ruby_lsp/setup_bundler.rb
Original file line number Diff line number Diff line change
Expand Up @@ -186,9 +186,22 @@ def run_bundle_install(bundle_gemfile = @gemfile)
env["BUNDLE_PATH"] = File.expand_path(env["BUNDLE_PATH"], @project_path)
end

path_parts = if Gem.win_platform?
ENV["Path"] || ENV["PATH"] || ENV["path"] || ""
else
ENV["PATH"] || ""
end.split(File::PATH_SEPARATOR)

bin_directory = File.expand_path("bin", @project_path)
bundle_binstub = File.join(@project_path, "bin", "bundle")

# If there's a Bundler version locked, then we need to use that one to run bundle commands, so that the composed
# lockfile is also locked to the same version. This avoids Bundler restarts on version mismatches
base_bundle = if @bundler_version
base_bundle = if File.exist?(bundle_binstub) && path_parts.any? do |path|
File.expand_path(path, @project_path) == bin_directory
end
bundle_binstub
elsif @bundler_version
env["BUNDLER_VERSION"] = @bundler_version.to_s
install_bundler_if_needed
"bundle _#{@bundler_version}_"
Expand Down
66 changes: 63 additions & 3 deletions test/integration_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,84 @@
require "test_helper"

class IntegrationTest < Minitest::Test
def setup
def test_ruby_lsp_doctor_works
skip("CI only") unless ENV["CI"]
end

def test_ruby_lsp_doctor_works
in_isolation do
system("bundle exec ruby-lsp --doctor")
assert_equal(0, $CHILD_STATUS)
end
end

def test_ruby_lsp_check_works
skip("CI only") unless ENV["CI"]

in_isolation do
system("bundle exec ruby-lsp-check")
assert_equal(0, $CHILD_STATUS)
end
end

def test_adds_bundler_version_as_part_of_exec_command
Dir.mktmpdir do |dir|
Dir.chdir(dir) do
File.write(File.join(dir, "Gemfile"), <<~GEMFILE)
source "https://rubygems.org"
gem "ruby-lsp", path: "#{Bundler.root}"
GEMFILE

Bundler.with_unbundled_env do
capture_subprocess_io do
system("bundle install")

Object.any_instance.expects(:exec).with do |env, command|
assert(env.key?("BUNDLE_GEMFILE"))
assert(env.key?("BUNDLER_VERSION"))
assert_match(/bundle _[\d\.]+_ exec ruby-lsp/, command)
end.once.raises(StandardError.new("stop"))

# We raise intentionally to avoid continuing running the executable
assert_raises(StandardError) do
load(Gem.bin_path("ruby-lsp", "ruby-lsp"))
end
end
end
end
end
end

def test_avoids_bundler_version_if_local_bin_is_in_path
Dir.mktmpdir do |dir|
Dir.chdir(dir) do
File.write(File.join(dir, "Gemfile"), <<~GEMFILE)
source "https://rubygems.org"
gem "ruby-lsp", path: "#{Bundler.root}"
GEMFILE

FileUtils.mkdir(File.join(dir, "bin"))
FileUtils.touch(File.join(dir, "bin", "bundle"))

Bundler.with_unbundled_env do
capture_subprocess_io do
system("bundle install")

Object.any_instance.expects(:exec).with do |env, command|
assert(env.key?("BUNDLE_GEMFILE"))
refute(env.key?("BUNDLER_VERSION"))
assert_equal("bundle exec ruby-lsp", command)
end.once.raises(StandardError.new("stop"))

ENV["PATH"] = "./bin#{File::PATH_SEPARATOR}#{ENV["PATH"]}"
# We raise intentionally to avoid continuing running the executable
assert_raises(StandardError) do
load(Gem.bin_path("ruby-lsp", "ruby-lsp"))
end
end
end
end
end
end

private

def in_isolation(&block)
Expand Down

0 comments on commit c00b6c8

Please sign in to comment.