This repository has been archived by the owner on Apr 14, 2021. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
7389: Wrap up `bundle cache` migration to current `bundle package` r=indirect a=deivid-rodriguez ### What was the end-user problem that led to this PR? The problem was that after #7249, we added the current `bundle package` functionality to the current `bundle cache` command, so that these commands are now aliases of each other. The initial plan was to do this in a more careful manner but we concluded that this was only _adding_ functionality to `bundle cache`, so not backwards incompatible. We still need to wrap up the original plan, where `bundle cache` is the preferred command. ### What is your fix for the problem, implemented in this PR? My fix is to migrate docs, tests and help text to use `bundle cache`, and to remove duplicated specs for `bundle cache` and `bundle package`, since they are testing the exact same code. Co-authored-by: David Rodríguez <[email protected]>
- Loading branch information
Showing
19 changed files
with
470 additions
and
474 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
.\" generated with Ronn/v0.7.3 | ||
.\" http://github.com/rtomayko/ronn/tree/0.7.3 | ||
. | ||
.TH "BUNDLE\-CACHE" "1" "October 2019" "" "" | ||
. | ||
.SH "NAME" | ||
\fBbundle\-cache\fR \- Package your needed \fB\.gem\fR files into your application | ||
. | ||
.SH "SYNOPSIS" | ||
\fBbundle cache\fR | ||
. | ||
.SH "DESCRIPTION" | ||
Copy all of the \fB\.gem\fR files needed to run the application into the \fBvendor/cache\fR directory\. In the future, when running [bundle install(1)][bundle\-install], use the gems in the cache in preference to the ones on \fBrubygems\.org\fR\. | ||
. | ||
.SH "GIT AND PATH GEMS" | ||
The \fBbundle cache\fR command can also package \fB:git\fR and \fB:path\fR dependencies besides \.gem files\. This needs to be explicitly enabled via the \fB\-\-all\fR option\. Once used, the \fB\-\-all\fR option will be remembered\. | ||
. | ||
.SH "SUPPORT FOR MULTIPLE PLATFORMS" | ||
When using gems that have different packages for different platforms, Bundler supports caching of gems for other platforms where the Gemfile has been resolved (i\.e\. present in the lockfile) in \fBvendor/cache\fR\. This needs to be enabled via the \fB\-\-all\-platforms\fR option\. This setting will be remembered in your local bundler configuration\. | ||
. | ||
.SH "REMOTE FETCHING" | ||
By default, if you run \fBbundle install(1)\fR](bundle\-install\.1\.html) after running bundle cache(1) \fIbundle\-cache\.1\.html\fR, bundler will still connect to \fBrubygems\.org\fR to check whether a platform\-specific gem exists for any of the gems in \fBvendor/cache\fR\. | ||
. | ||
.P | ||
For instance, consider this Gemfile(5): | ||
. | ||
.IP "" 4 | ||
. | ||
.nf | ||
|
||
source "https://rubygems\.org" | ||
|
||
gem "nokogiri" | ||
. | ||
.fi | ||
. | ||
.IP "" 0 | ||
. | ||
.P | ||
If you run \fBbundle cache\fR under C Ruby, bundler will retrieve the version of \fBnokogiri\fR for the \fB"ruby"\fR platform\. If you deploy to JRuby and run \fBbundle install\fR, bundler is forced to check to see whether a \fB"java"\fR platformed \fBnokogiri\fR exists\. | ||
. | ||
.P | ||
Even though the \fBnokogiri\fR gem for the Ruby platform is \fItechnically\fR acceptable on JRuby, it has a C extension that does not run on JRuby\. As a result, bundler will, by default, still connect to \fBrubygems\.org\fR to check whether it has a version of one of your gems more specific to your platform\. | ||
. | ||
.P | ||
This problem is also not limited to the \fB"java"\fR platform\. A similar (common) problem can happen when developing on Windows and deploying to Linux, or even when developing on OSX and deploying to Linux\. | ||
. | ||
.P | ||
If you know for sure that the gems packaged in \fBvendor/cache\fR are appropriate for the platform you are on, you can run \fBbundle install \-\-local\fR to skip checking for more appropriate gems, and use the ones in \fBvendor/cache\fR\. | ||
. | ||
.P | ||
One way to be sure that you have the right platformed versions of all your gems is to run \fBbundle cache\fR on an identical machine and check in the gems\. For instance, you can run \fBbundle cache\fR on an identical staging box during your staging process, and check in the \fBvendor/cache\fR before deploying to production\. | ||
. | ||
.P | ||
By default, bundle cache(1) \fIbundle\-cache\.1\.html\fR fetches and also installs the gems to the default location\. To package the dependencies to \fBvendor/cache\fR without installing them to the local install location, you can run \fBbundle cache \-\-no\-install\fR\. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
BUNDLE-CACHE(1) BUNDLE-CACHE(1) | ||
|
||
|
||
|
||
NAME | ||
bundle-cache - Package your needed .gem files into your application | ||
|
||
SYNOPSIS | ||
bundle cache | ||
|
||
DESCRIPTION | ||
Copy all of the .gem files needed to run the application into the ven- | ||
dor/cache directory. In the future, when running [bundle | ||
install(1)][bundle-install], use the gems in the cache in preference to | ||
the ones on rubygems.org. | ||
|
||
GIT AND PATH GEMS | ||
The bundle cache command can also package :git and :path dependencies | ||
besides .gem files. This needs to be explicitly enabled via the --all | ||
option. Once used, the --all option will be remembered. | ||
|
||
SUPPORT FOR MULTIPLE PLATFORMS | ||
When using gems that have different packages for different platforms, | ||
Bundler supports caching of gems for other platforms where the Gemfile | ||
has been resolved (i.e. present in the lockfile) in vendor/cache. This | ||
needs to be enabled via the --all-platforms option. This setting will | ||
be remembered in your local bundler configuration. | ||
|
||
REMOTE FETCHING | ||
By default, if you run bundle install(1)](bundle-install.1.html) after | ||
running bundle cache(1) bundle-cache.1.html, bundler will still connect | ||
to rubygems.org to check whether a platform-specific gem exists for any | ||
of the gems in vendor/cache. | ||
|
||
For instance, consider this Gemfile(5): | ||
|
||
|
||
|
||
source "https://rubygems.org" | ||
|
||
gem "nokogiri" | ||
|
||
|
||
|
||
If you run bundle cache under C Ruby, bundler will retrieve the version | ||
of nokogiri for the "ruby" platform. If you deploy to JRuby and run | ||
bundle install, bundler is forced to check to see whether a "java" | ||
platformed nokogiri exists. | ||
|
||
Even though the nokogiri gem for the Ruby platform is technically | ||
acceptable on JRuby, it has a C extension that does not run on JRuby. | ||
As a result, bundler will, by default, still connect to rubygems.org to | ||
check whether it has a version of one of your gems more specific to | ||
your platform. | ||
|
||
This problem is also not limited to the "java" platform. A similar | ||
(common) problem can happen when developing on Windows and deploying to | ||
Linux, or even when developing on OSX and deploying to Linux. | ||
|
||
If you know for sure that the gems packaged in vendor/cache are appro- | ||
priate for the platform you are on, you can run bundle install --local | ||
to skip checking for more appropriate gems, and use the ones in ven- | ||
dor/cache. | ||
|
||
One way to be sure that you have the right platformed versions of all | ||
your gems is to run bundle cache on an identical machine and check in | ||
the gems. For instance, you can run bundle cache on an identical stag- | ||
ing box during your staging process, and check in the vendor/cache | ||
before deploying to production. | ||
|
||
By default, bundle cache(1) bundle-cache.1.html fetches and also | ||
installs the gems to the default location. To package the dependencies | ||
to vendor/cache without installing them to the local install location, | ||
you can run bundle cache --no-install. | ||
|
||
|
||
|
||
October 2019 BUNDLE-CACHE(1) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.