ActionsのデフォルトNode.jsメジャーバージョン変更が延期など|Productivity Weekly(2024-05-22)
こんにちは。サイボウズ株式会社 生産性向上チームの平木場です。
僕たち生産性向上チームは毎週水曜日に Productivity Weekly という「1 週間の間に発見された開発者の生産性向上に関するネタを共有する会」を社内で開催しています。
本記事はその時のネタをまとめたものです。
2023-01-25 号から、基本的に隔週で連載することとしました。たまに単独でも投稿するかもしれません。
今週は 2024-05-22 単独号です。
今回が第 153 回目です。過去の記事はこちら。
news 📺
Updated dates for Actions runner using Node20 instead of Node16 by default - The GitHub Blog
GitHub Actions で JavaScript の action を動かすための Node.js のバージョンが v16 から v20 に変更される予定についての続報です。
この変更内容については 2024-03-13 の Productivity Weekly で詳しく解説していますので、合わせてご覧ください。
3 月のアナウンスでは 5/13[1]から v20 が強制的に利用される予定でしたが、その日程が 6/30 に延期となったようです。
また前回のアナウンスからの差分として、ランナーに内蔵されている Node.js v16 が 10 月に削除されることが告知されています。よって、オプトアウト用の ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true
を設定して v16 を使い続けていたとしても、10 月以降はそれも不可能になるようです。
もしまだ v20 に対応していない action を利用されている場合は、最新バージョンで v20 に対応しているかを確認するなどして、そろそろ v16 へ依存しないようにしておきましょう。
本項の執筆者: @Kesin11
Actions: Upcoming changes to GitHub-hosted macOS runners - The GitHub Blog
GitHub Actions において、macOS ランナーの最近・今後の変更が発表されました。これまで発表されていた内容と被る部分が多いですが、今後の変更がまとまっています。
- 全ての
macos-latest
が macOS 14 を使うようになった - macOS 11 の削除が 6/28 に決定
- ユーザに削除を意識させるために、6/17, 19, 24, 26 の特定の時間(EST)に macOS 11 ランナーが使えなくなる
- 以前から 2024/06 末までに削除することは告知されていた
- macOS ランナーの IP レンジを確認できるようになった
-
GET /meta の API レスポンスに含まれる、
actions_macos
を参照することで取得できる-
gh api /meta
"actions_macos": [ "13.105.117.0/31", "13.105.117.10/31", "13.105.117.100/31", "13.105.117.102/31",
-
- IP アドレスは不変ではないことに注意
-
GET /meta の API レスポンスに含まれる、
特に macOS 11 ランナーを利用している人は早く移行するようにしましょう。
本項の執筆者: @korosuke613
Introducing GitHub Copilot Extensions: Unlocking unlimited possibilities with our ecosystem of partners - The GitHub Blog
GitHub Copilot に Extensions 機能が追加されました(リミテッドパブリックベータ)。
Copilot Extensions は、Copilot に特定のサービスやツールを統合するための機能です。例えば、Docker extension の場合、Docker に関する質問への回答の精度が上がるだけでなく、リポジトリの内容から Dockerfile を生成させてそのままプルリクエストを作成させるや、Docker Scout を使って脆弱性の検出をさせることもできるようです。
他には、Microsoft 365 や Sentry、DataStax などのサービスが拡張機能の提供に名乗りを上げています。
現段階で利用できる Copilot Extensions は次の通りです。
https://github.com/marketplace?type=apps&copilot_app=true
しかし、この機能はまだリミテッドパブリックベータであり、だんだんと使えるユーザが増えてくるようです[2]。
なお、Copilot Business、Copilot Enterprise を利用している場合、Organization レベルで Copilot Extensions をインストールする必要があるようです。
Anyone can install a Copilot Extension on their personal account. However, if they get access to Copilot through a Copilot Business or Copilot Enterprise subscription, they will only be able to use the extension if it is installed at the organization level.
https://docs.github.com/ja/copilot/github-copilot-chat/github-copilot-extensions/installing-github-copilot-extensions-for-your-organization#about-installing-github-copilot-extensions-for-your-organization
また関連する情報として、今回の Copilot Extensions は自前で実装することも可能なようです。こちらに関しては、試してみた方が記事を書いており、どんなものなのかわかりやすいです。
GitHub Copilot を 3rd party が拡張できるようになることで、より多くのユースケースに対応できるようになりますね。僕も触ってみたいものです。
Copilot Extensions について詳しく知りたい方はドキュメントも参照ください。
本項の執筆者: @korosuke613
know-how 🎓
2024/05/16 に開催された GitHub Actions Meetup Tokyo #3 での LT 資料が公開されています。
TypeScript Custom GitHub Action Development Tips - Speaker Deck
JavaScript/TypeScript で GitHub Actions を開発する際のノウハウを紹介しています。テストの書き方、便利ライブラリ、リリース戦略などが紹介されています。
特に面白かったのは Action の利用者に Branch でのバージョン指定をできなくしている点です。Action 利用のベストプラクティスを Action の公開側が提供するのは親切でとても良いですね。
本項の執筆者: @r4mimu
GitHub Actionsの痒いところを埋めるサードパーティーランナー - Speaker Deck
GitHub Actions を実行するランナーには GitHub が提供する公式ランナー以外に、自前でランナーを用意する Self-hosted runner があります。この Self-hosted runner の仕組みを利用して、ランナーを提供するプロバイダーがいくつかあり、それらのサービスのランナーを紹介しています。CPU アーキテクチャ、マシンスペック、料金体系、起動時間などについて比較してくださっており、導入時の参考になります。
料金面やマシンスペック、CPU アーキテクチャに関しては GitHub 公式ランナーよりも優位性がありますが Cache や Artifact が遅いことやセキュリティ上の懸念にも触れられています。
個人的には Namespace のランナーは CPU やメモリ使用率が見られるダッシュボードがあるのが面白いと思いました。GitHub 公式も提供して欲しいですね。
本項の執筆者: @r4mimu
E2Eテストワークフローを高速化・安定化させる取り組み | ドクセル
GitHub Actions の Self-hosted runner 上で実行している E2E テストの高速化・安定化についての取り組みについて @r4mimu が発表しました。
ワークフローのボトルネックを計測し、それに対して実行時間と失敗率の 2 つの観点から改善をした取り組みを紹介しています。
具体的には、テストに用いる Docker image のキャッシュ、パッケージのキャッシュ、ワークフローの自動リトライ、テストケースの再実行戦略の導入などを紹介していますので、よかったらご覧ください。
本項の執筆者: @r4mimu
read more 🍘
Productivity Weekly で出たネタを全て紹介したいけど紹介する体力が持たなかったネタを一言程度で書くコーナーです。
-
tool 🔨
-
@power-assert/node: power-assert custom hook for Node Test Runner
-
Node.jsが自前でテスティングフレームワークやassert関数、ESM読み込み時のカスタムフックなどを備える時代になったので、--importするだけで動くpower-assertを作りました
https://x.com/t_wada/status/1792394995498205185 - t-wada さんが、Node.js の assert 関数を拡張する power-assert というツールを公開してました
- power-assert は assert 関数の引数に渡された値や式の評価を細かく可視化してくれるツールです
- インストールして使うだけでなく、Node.js 実行時に
--import @power-assert/node
とすることで、assert 関数を power-assert に置き換えられるようです。便利 - assert 関数を使う際は覚えておきたいですね
-
-
@power-assert/node: power-assert custom hook for Node Test Runner
本項の執筆者: @korosuke613
あとがき
今週号でした。GitHub の話題が多いですね(いつものこと)。今 2 週間遅れを繰り返してて良くないので遅れを取り戻したいです。
サイボウズの生産性向上チームでは社内エンジニアの開発生産性を上げるための活動を行なっています。そんな生産性向上チームが気になる方は下のリンクをクリック!
Discussion