diff --git a/lib/capistrano/locally.rb b/lib/capistrano/locally.rb index 17d93e0..86b7f22 100644 --- a/lib/capistrano/locally.rb +++ b/lib/capistrano/locally.rb @@ -24,7 +24,11 @@ def on(hosts, options={}, &block) end if (defined? Bundler) && with_unbundled_env? - Bundler.with_unbundled_env do + if Bundler.respond_to?(:with_unbundled_env) + Bundler.method(:with_unbundled_env) + else + Bundler.method(:with_clean_env) + end.call do klass.new(localhost, &block).run end else @@ -36,7 +40,9 @@ def on(hosts, options={}, &block) end def with_unbundled_env? - fetch_setting_related_bundler_with_unbundled_env + [deprecated_with_unbundled_env?, fetch(:run_locally_with_unbundled_env, true)].find do |val| + !val.nil? + end end private @@ -45,24 +51,13 @@ def dry_run? fetch(:sshkit_backend) == SSHKit::Backend::Printer end - def fetch_setting_related_bundler_with_unbundled_env - value = fetch(:run_locally_with_unbundled_env) - value = fetch_run_locally_with_clean_env if value.nil? - value = true if value.nil? - - value - end - - def fetch_run_locally_with_clean_env - value = fetch(:run_locally_with_clean_env) - - unless value.nil? - $stderr.puts(<<-MESSAGE) -[Deprecation Notice] `set :run_locally_with_clean_env` has been deprecated in favor of `set :run_locally_with_unbundled_env`. -MESSAGE + def deprecated_with_unbundled_env? + fetch(:run_locally_with_clean_env).tap do |val| + $stderr.puts(<<~MESSAGE) unless val.nil? + [Deprecation Notice] `set :run_locally_with_clean_env` has been deprecated \ + in favor of `set :run_locally_with_unbundled_env`. + MESSAGE end - - value end end end diff --git a/lib/capistrano/locally/version.rb b/lib/capistrano/locally/version.rb index be5da4f..8f42369 100644 --- a/lib/capistrano/locally/version.rb +++ b/lib/capistrano/locally/version.rb @@ -1,5 +1,5 @@ module Capistrano module Locally - VERSION = "0.2.7" + VERSION = "0.3.0" end end diff --git a/spec/capistrano/locally_spec.rb b/spec/capistrano/locally_spec.rb index 0de4612..d2668f9 100644 --- a/spec/capistrano/locally_spec.rb +++ b/spec/capistrano/locally_spec.rb @@ -47,6 +47,29 @@ class DummyDSL expect(dsl.with_unbundled_env?).to be_truthy end end + + context 'with the :run_locally_with_unbundled_env is set to true' do + it 'returns truthy' do + dsl.set(:run_locally_with_unbundled_env, true) + expect(dsl.with_unbundled_env?).to be_truthy + dsl.set(:run_locally_with_unbundled_env, nil) + end + end + context 'with the old key :run_locally_with_clean_env is set to true' do + around do |example| + dsl.set(:run_locally_with_clean_env, true) + example.run + dsl.set(:run_locally_with_clean_env, nil) + end + it 'returns truthy' do + expect(dsl.with_unbundled_env?).to be_truthy + end + it 'shows a Deprecation message' do + expect { dsl.with_unbundled_env? }.to output(/\[Deprecation Notice\]/).to_stderr + end + end + + context 'with the :run_locally_with_unbundled_env is set to false' do it 'returns falsy' do dsl.set(:run_locally_with_unbundled_env, false)