Check your Ruby gems for compatibility with all major Rails versions.
The app is live at https://railsbump.org/, where you can check an individual gem or a whole Bundler lockfile (Gemfile.lock).
RailsBump uses a few approaches to check whether a gem version is compatible with a specific Rails release:
- if the gem version has a direct dependency on one of the "Rails gems" (rails, railties, activerecord, activesupport, etc.), it may be clear that it is not compatible with some Rails releases immediately
- if the gem version has a dependency on a specific version of another gem that we already know is not compatible with a Rails release, this gem version is not compatible either,
- if all other approaches don't work, RailsBump simply puts the gem version and a Rails release in a Gemfile and lets Bundler figure it out. If the gem can be successfully installed along with the Rails release, it counts as "compatible".
Since some gems have a lot of versions and each one needs to be checked against multiple Rails releases, this could get out of hand quickly. To minimize the amount of compatibility checks that need to be done, the gem versions are grouped by their dependencies first. If multiple versions (of the same gem or even of different gems) have the same dependencies, a single check is enough to determine whether all of them are compatible with a specific Rails release or not.
To actually perform the check, GitHub Actions are used. For each check, a new branch is creted in a separate repository, which triggers a workflow that essentially tries to run bundle lock
and reports the result back to the RailsBump app via a webhook.
RailsBump used to be called Ready4Rails until December 2019, when Manuel Meurer took over from Florent Guilleux to automate the service that Ready4Rails had been doing more or less manually until then.
The relaunch took longer than expected, mainly because of the Coronavirus pandemic, and the first usable version of RailsBump was finally launched in August 2020.
You can see live stats from Plausible Analytics here: https://plausible.io/railsbump.org
If you notice a bug or have an idea for an improvement, please open an issue or submit a PR.
If you'd like to get involved in the development, get in touch via email!
You will need these services:
- Postgres 16 or higher
- Redis
In order to set up the application locally:
git clone [email protected]:railsbump/app.git
bin/setup
rake data:find_or_create_rails_releases
foreman start -f Procfile.dev
- Go to http://localhost:3000
If these steps don't work, please submit a new issue: https://github.com/railsbump/app/issues/new
We recommend running these scheduled tasks:
-
bin/rails runner "Compats::CheckUnchecked.call"
once every 5 to 10 minutes -
bin/rails runner "Maintenance::Hourly.call"
once an hour
If you find RailsBump useful and would like to support the ongoing development, please consider submitting an issue or become a sponsor!
This project is licensed under the MIT License - see the LICENSE.txt file for details.