📶 Stairstep is a Ruby gem that simplifies the process of deploying Rails applications to Heroku. It provides a streamlined workflow for deploying and promoting applications across different Heroku environments.
Before installing Stairstep, ensure you have:
- Ruby 3.2.0 or higher installed
- Git installed and configured
- Heroku CLI installed and authenticated (
heroku login) - Heroku Builds plugin* installed:
heroku plugins:install @heroku-cli/heroku-builds - A Rails application with a Git repository
- Heroku applications and pipeline set up
Add this line to your application's Gemfile:
gem 'stairstep'And then execute:
$ bundle installOr install it yourself as:
$ gem install stairstepYou may add an optional stairstep.yml file in the application's config/ directory to customize Stairstep's behavior.
You may optionally specify the name of the pipeline for deploys. By default, this is the name of the GitHub repository.
You may optionally specify app names per remote. This will default to the hyphenated combination of the pipeline name and the remote name (e.g. syrup-demo).
Top level config keys may be the name of a Heroku deploy hook. Each key within a hook is a Heroku CLI command. Each value is an array of parameters for that command.
before_deployRuns right before the deploy (during maintenance mode)after_deployRuns at the very end (after maintenance mode)
---
pipeline: wibble-wobble
demo:
app: wib-wob-demo
staging:
app: wib-wob-staging
production:
app: wibble-wobble-prod
before_deploy:
config:unset:
- MINOR_VERSION
config:set:
- DEPLOY_TIME=`date +%s`
after_deploy:
run:
- rails pusher:new_release rollbar:source_maps
- rails db:seed:staticStairstep provides two main commands: deploy and promote.
For information on available commands and options, use:
$ stairstep --help
$ stairstep deploy --help
$ stairstep promote --helpTo deploy your application to a specific Heroku environment:
$ stairstep deploy ENVIRONMENT [options]For detailed deploy documentation, see here.
To promote your application from one environment to another:
$ stairstep promote ENVIRONMENT [options]For detailed promote documentation, see here.
Everyone interacting in the Stairstep project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.
The gem is available as open source under the terms of the MIT License.