From 5640b7b81615a496c463bfa35834d0b4763e3816 Mon Sep 17 00:00:00 2001 From: Samuel Giddins Date: Mon, 12 Jun 2017 11:22:08 -0500 Subject: [Viz] Work correctly when another gem with a graphviz file is present --- lib/bundler/cli/viz.rb | 3 +++ spec/commands/viz_spec.rb | 47 +++++++++++++++++++++++++++++++++++++++++++---- spec/support/helpers.rb | 2 ++ 3 files changed, 48 insertions(+), 4 deletions(-) diff --git a/lib/bundler/cli/viz.rb b/lib/bundler/cli/viz.rb index 418c462a93..767fe8f3de 100644 --- a/lib/bundler/cli/viz.rb +++ b/lib/bundler/cli/viz.rb @@ -7,6 +7,9 @@ module Bundler end def run + # make sure we get the right `graphviz`. There is also a `graphviz` + # gem we're not built to support + gem "ruby-graphviz" require "graphviz" options[:without] = options[:without].join(":").tr(" ", ":").split(":") diff --git a/spec/commands/viz_spec.rb b/spec/commands/viz_spec.rb index 9ab8215aa1..0e8667eaa7 100644 --- a/spec/commands/viz_spec.rb +++ b/spec/commands/viz_spec.rb @@ -1,13 +1,13 @@ # frozen_string_literal: true RSpec.describe "bundle viz", :ruby => "1.9.3", :if => Bundler.which("dot") do - let(:graphviz_lib) do - graphviz_glob = base_system_gems.join("gems/ruby-graphviz*/lib") - Dir[graphviz_glob].first + let(:ruby_graphviz) do + graphviz_glob = base_system_gems.join("cache/ruby-graphviz*") + Pathname.glob(graphviz_glob).first end before do - ENV["RUBYOPT"] = "-I #{graphviz_lib}" + system_gems ruby_graphviz end it "graphs gems from the Gemfile" do @@ -74,6 +74,45 @@ RSpec.describe "bundle viz", :ruby => "1.9.3", :if => Bundler.which("dot") do EOS end + context "with another gem that has a graphviz file" do + before do + build_repo4 do + build_gem "graphviz", "999" do |s| + s.write("lib/graphviz.rb", "abort 'wrong graphviz gem loaded'") + end + end + + system_gems ruby_graphviz, "graphviz-999", :gem_repo => gem_repo4 + end + + it "loads the correct ruby-graphviz gem" do + install_gemfile <<-G + source "file://#{gem_repo1}" + gem "rack" + gem "rack-obama" + G + + bundle! "viz", :format => "debug" + expect(out).to eq(strip_whitespace(<<-DOT).strip) + digraph Gemfile { + concentrate = "true"; + normalize = "true"; + nodesep = "0.55"; + edge[ weight = "2"]; + node[ fontname = "Arial, Helvetica, SansSerif"]; + edge[ fontname = "Arial, Helvetica, SansSerif" , fontsize = "12"]; + default [style = "filled", fillcolor = "#B9B9D5", shape = "box3d", fontsize = "16", label = "default"]; + rack [style = "filled", fillcolor = "#B9B9D5", label = "rack"]; + default -> rack [constraint = "false"]; + "rack-obama" [style = "filled", fillcolor = "#B9B9D5", label = "rack-obama"]; + default -> "rack-obama" [constraint = "false"]; + "rack-obama" -> rack; + } + debugging bundle viz... + DOT + end + end + context "--without option" do it "one group" do install_gemfile <<-G diff --git a/spec/support/helpers.rb b/spec/support/helpers.rb index 3f1c0a3068..f54b25e42a 100644 --- a/spec/support/helpers.rb +++ b/spec/support/helpers.rb @@ -250,6 +250,8 @@ module Spec path = if g == :bundler Dir.chdir(root) { gem_command! :build, "#{root}/bundler.gemspec" } bundler_path = root + "bundler-#{Bundler::VERSION}.gem" + elsif g.to_s =~ %r{\A/.*\.gem\z} + g else "#{gem_repo}/gems/#{g}.gem" end -- cgit v1.2.1