Skip to content
/ app Public

Check which gems are compatible with which Rails version!

License

Notifications You must be signed in to change notification settings

railsbump/app

Repository files navigation

👊 RailsBump

Test

Check your Ruby gems for compatibility with all major Rails versions.

Usage

The app is live at https://railsbump.org/, where you can check an individual gem or a whole Bundler lockfile (Gemfile.lock).

Behind the scenes

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.

History

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.

Stats

You can see live stats from Plausible Analytics here: https://plausible.io/railsbump.org

Contributing

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!

Setup

You will need these services:

  • Postgres 16 or higher
  • Redis

In order to set up the application locally:

  1. git clone git@github.com:railsbump/app.git
  2. bin/setup
  3. rake data:find_or_create_rails_releases
  4. foreman start -f Procfile.dev
  5. 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

Support

If you find RailsBump useful and would like to support the ongoing development, please consider submitting an issue or become a sponsor!

License

This project is licensed under the MIT License - see the LICENSE.txt file for details.