This is a simplified, but fairly thorough, set of scripts and configuration to enable Heroku Release Phase for Rails apps.
Further, this particular set up plays nicely with Heroku Review Apps in that the release phase script will:
- Fail, loudly, if the DB does not yet exist.
- Load the DB schema if the current schema version (as determined by
bin/rails db:version) is0. - Run DB migrations otherwise.
For a "normal" app that usually means it will run the DB migrations.
For a Review App, on the first deploy the release phase will bin/rails db:schema:load.
And then the postdeploy script will seed data.
During subsequent deploys to the Review App, the release phase will bin/rails db:migrate.
Is the shell script even necessary? Now
app.jsoncallsrake heroku:review_app:postdeployand theProcfilecallsrake heroku:release.Personally, I think this has a few benefits
rakecall, cutting down on time spent calling it multiple disparate timesmulti-procfilebuildpack to separate review, staging, and production. They could each call their ownheroku:<ENV>:release)