Heroku Advent Calendar 2019 初日のuskさんに振られてビックリしちゃいましたが、Review Apps (New)ネタです。
11月7日に更新された Review Apps
2016年に最初のリリースが行われた Heroku Flow の Review Apps ですが、2019年10月17日に New Review Apps のパブリックベータが開始されており、11月7日にめでたく GA となりました。
10月17日 New Review Apps now in Public Beta
11月7日 New Review Apps now generally available
新しい Review Apps では、以下の様な機能追加・変更が行われています。
The new Review Apps includes a public-facing API, the ability to enable review apps in multiple pipelines for the same repository, the option to create Review Apps manually without a PR, and improvements to the Heroku Dashboard.
超訳
新しい Review Apps には、公開API、単一のリポジトリを複数のパイプラインで利用する機能、プルリクエストなしで Review Apps を手動で作成するオプション、および、Heroku ダッシュボードの改善が含まれています。
最も大きな変更は、プルリクエストなしで、ブランチから Review Apps を手動で作成できることだと思います(少なくとも個人的には、これが1番の変更点だと思っています)。ということで、この Review Apps の手動作成について、掘り下げてみたいと思います。
Heroku ダッシュボード上での変更点
大きく変更になったのは以下の点です。
- Pipeline の最初のページで、Review Apps を Enable にするパネルが派手になったw
と説明してきました。確かに、プルリクエストと連携することにより、レビュー環境の作成・削除を自動化できるというメリットはありましたし、実際にかなり便利な機能だと思っていました(いうまでもなく、今でも便利です)。
しかし、実際の開発現場で、プルリクエストを作成する前の状況、つまり(ほとんどの場合)ローカルの環境を考えてみると、Heroku 上の運用環境とは、結構異なった状況で開発していることが少なくないと思います。普通に考えれば、プログラミングをする環境は、Mac だったり、Windows だったりする場合も多く、その状況というのは、The Twelve-Factor App X. 開発/本番一致で解説されている**「継続的デプロイしやすいよう開発環境と本番環境のギャップを小さく保つ」**とは、大きく状況が異なっているともいえるわけです。
「じゃあ、実際に Heroku で動かしてみるために、頻繁にプルリクあげればいいじゃん」って感じもするのですが、頻繁にプルリクエストを作成してたら、リポジトリの運用に悪影響があるのは当然ですし、シャイなwいち開発者としては、やっぱりこっそり、Heroku 上で動かしてみたくなるのは当然です。
今回、手動で Review Apps を作成できるようになったことで、いち開発者としては、プルリクエスト無しに、アプリケーションの動作を Heroku 上で確認できるようになり、ローカルではちゃんと動作してたのに、Heroku 上にデプロイしたら、動かなくなってしまった!的な状況のママ、プルリクエストを飛ばしてしまうという恥ずかしい事をしなくてよくなります。
手動で Review Apps を作成する場合の注意点とその対策
少なくとも1点、十分気をつけなければならないことがあります。プルリクエストに応じて、Review Apps が作成・削除されていた旧バージョンの Review Apps では、プルリクエストの管理=Review Appsの管理だったのが、手動で作成した Review Apps の場合、当然ですが、手動で削除する必要があります。不要になったのに放置すれば、その分、課金は進みます。
ということで、不要になった Review Apps の削除は忘れずにね!ということになりますが、削除を忘れてしまった場合でも、課金がすすまないようにする対策として、Heroku ダッシュボードでは、一定期間経過後、強制的に削除するための設定が Review Apps の設定に追加されています。
この設定では、デプロイ後、該当ブランチの更新が無ければ、指定した日数後に、自動的にその Review Apps が削除されます。標準では、この設定はオフになっているので、Review Apps の手動デプロイを設定した場合は、忘れずに、削除の設定も合わせておこなっておくのが良いでしょう。
従来通りの Review Apps の使い方を踏襲したい場合は
なお、従来通り、プルリクエストベースで、Review Apps を作成・削除するという場合においては、Review Apps の設定で、「reate new review apps for new pull requests automatically」をチェックしておくことで対応可能です。