bundle exec
現在のbundleのコンテキストで、スクリプトを実行します。
文法
bundle exec [--keep-file-descriptors] command
説明
このコマンドは、Rubyプログラムで必要とされるGemfile(5)内で指定されている全てのGemを利用可能にして、 そのコマンドを実行します。
基本的に、もしrspec spec/my_spec.rb
のように何らかのコマンドを実行し、
Gemfile(5)内のGemを使用して、
bundle install(1)を通してインストールしたいのであれば、
bundle exec rspec spec/my_spec.rb
として実行するべきです。
bundle exec
は、シェルの$PATH
上で利用可能な実行ファイルを必要としないことに注意して下さい。
オプション
bundle install -binstubs
もし、bundle install(1)内で--binstubs
フラグを使用した場合、
Bundlerは自動的に、bundle内のGemから利用可能な全ての実行ファイルを含むディレクトリ(デフォルトはapp_root/bin
)を作成します。
--binstubs
の使用後のbin/rspec spec/my_spec.rb
の実行は、
bundle exec rspec spec/my_spec.rb
と同一の処理になります。
環境の変更
bundle exec
はシェル環境に対して多数の変更を行い、次に指定されたコマンドを全て実行します。
-
bundle exec
($BUNDLE_BIN_PATH
を使用して)によって実行された内部コマンドから、bundle
へシェル出力を行う事が可能かを確認します。 -
$PATH
上のbundleのために、 実行ファイル(rails
、rspec
、rackup
)を含むディレクトリを配置します。 -
Bundlerがそのサブシェル内から実行された場合、同じGemfile(
BUNDLE_GEMFILE
の設定によって)を使用することを確認します。 -
$RUBYOPT
に-rbundler/setup
を追加し、 サブシェル内で実行されるRubyプログラムがbundle内のGemを参照出来ることを確認します。
また、Rubygemsも変更します。
- Bundle内に無いGemの読み込みを禁止します。
-
もし、要件にマッチするGemがbundle内にあれば、そのGemメソッドをno-op(何も行わない処理)に変更し、
もし、それが無ければ
Gem::LoadError
を発生させます。 -
sourceインデックスはBundlerを使用する際は常に凍結されるため、
Gem.refresh
をno-op(何も行わない処理)に定義し、 環境変数内へのシステム漏れからGemを保護します。(翻訳に自信なし) -
bundle内でGemを使用するために
Gem.bin_path
を上書きし、 システムの実行ファイルを機能させます。 -
bundle内の全てのGemを、
Gem.loaded_specs
内へ追加します。
シェル出力
サブシェル(system
、バッククォート、%x{}
等)を開くRubyのコードは、
自動的に現在のBundler環境を使用します。
もし、あなたのbundleの一部では無いRubyコマンドへのシェル出力が必要な場合、
ブロックとwith_clean_env
を使用して下さい。
ブロック内部で作成されたサブシェルは、Bunlderが有効になる前の環境が与えられます。
例えば、HomebrewコマンドはRubyを実行しますが、bundle内部では動作しません。
Bundler.with_clean_env do
`brew install wget`
end
異なるbundleへシェル出力を行う場合にも、
with_clean_env
の使用が必要になります。
サブシェル内の一部のBundlerコマンドは、現在のGemfileを継承するため、
異なるbundleのコンテキストでの実行が必要なコマンドも、with_clean_env
が必要になります。
Bundler.with_clean_env do
Dir.chdir "/other/bundler/project" do
`bundle exec ./script`
end
end
Bundlerはsystem
とexec
でラップする便利なヘルパーを提供し、
これらは次のようにして使用することが出来ます。
Bundler.clean_system('brew install wget')
Bundler.clean_exec('brew install wget')
RubyGemsプラグイン
現在、Rubygemsプラグインのシステムでは、あるRubyコードがrubygems.rb
を必要とする際に、
インストールされたGemの読み込みパス(load path)上のrubygems_plugin.rb
という名前の全てのファイルを必要とします。
これはrails
、rackup
、rspec
のような、
システムへインストールされる実行ファイルを含みます。
Rubygemsプラグインは任意のRubyコードを含むため、 一般的にはそれらが自分自身とその依存性を有効にします。
例えば、gemcutter 0.5
のGemはjson_pure
に依存します。
もし、インストールされたgemcutter
(この問題抜きに、新しいバージョンであるとしても)があれば、
Rubygemsはgemcutter 0.5
とjson_pure <latest>
を有効にします。
もし、Gemfile(5)にもjson_pure
が含まれる(または、json_pure
に依存するGemがある)場合、
あなたのシステムの最新のバージョンで、Gemfile(5)のバージョン、
またはGemfile.lock内のスナップショットのバージョンが衝突を起こすかもしれません。
もしこれが起こると、Bundlerは次のように報告してきます。
You have already activated json_pure 1.4.6 but your Gemfile
requires json_pure 1.4.3. Consider using bundle exec.
(既にjson_pure 1.4.6が有効にされていますが、Gemfileはjson_pure 1.4.3を必要としています。 bundle execの使用を検討してください。)
このような状況では、あなたはきっと問題を起こしているGemプラグインと一緒に、根本的な原因であるGemを削除したくなるでしょう。 通常、これらのプラグイン(この場合は、gemcutterのGem)の作者は、 より慎重な新しいバージョンをリリースしています。
次のように実行することで、Gemプラグインを含めた全てのGemのリストを確認することが出来ます。
ruby -rubygems -e "puts Gem.find_files('rubygems_plugin.rb')"
少なくとも、各Gemプラグインの最新のバージョンでは無いものを全てを削除し、
使用してしない全てのGemプラグインも削除するべきです。(gem uninstall gem_name
)
© 2010 - 2017 STUDIO KINGDOM