Home

Awesome

👊 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:

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:

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:

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.