LoginSignup
9
1

More than 1 year has passed since last update.

renovate を使って依存関係の更新を自動検知できるようにしてみた

Last updated at Posted at 2022-12-21

これは EDOCODE Advent Calendar 2022 12月21日の記事です。

フロントエンドエンジニアの Kaori です。

今期に依存関係更新自動検知のためにフロントエンドで導入した renovate について紹介します。

renovate とは

依存関係のバージョンを管理し、依存関係の更新を自動的に検知してくれます。
オプションもさまざまあり、開発に合わせてカスタマイズできます。

GitHub の場合は renovate をプロジェクトにダウンロードするだけで簡単に導入できるようです。

弊社では GitLab のセルフホストを利用しているため、少し設定が必要でしたので、その方法から紹介します。

GitLab セルフホストでの設定方法

GitLab パイプラインで実行する場合は、簡単にセットアップできるパイプラインテンプレート(Renovate Runner)が提供されており利用が推奨されていました、ここではそのテンプレート Renovate Runner のプロジェクトを self-hosted で設定する方法を説明します。

  1. renovate-runner を clone します。

  2. Renovate Runner を実行するための新しいプロジェクトを作成します。

  3. renovate 用のパーソナルアクセストークンを作成します。

    1. renovate runner 用の GitLab のパーソナルアクセストークンを作成します。
      スコープは api, read_user, write_repository を選択してください。

      img_token.png

    2. GitHub のパーソナルアクセストークンを作成します。
      これは必須ではありませんが、設定することで Renovate の MR で release note の更新履歴などが確認できるようになります。
      スコープは何も選ばなくて大丈夫です。

    3. renovate runner 用の GitLab のパーソナルアクセストークンを作成します。
      スコープは api, read_user, write_repository を選択してください。

  4. CI/CD 変数を設定します。

    1. 作成した Renovate Runner のプロジェクト で 変数を設定します。
      Settings > CI/CD > Variables に以下のように設定します。

      Key Value
      RENOVATE_TOKEN 作成した GitLab のアクセストークン
      GITHUB_COM_TOKEN 作成した GitHub のアクセストークン
      RENOVATE_EXTRA_FLAGS renovate を実行して自動更新したいプロジェクトレポジトリ

      img_variables.png

    2. renovate の設定がまだないプロジェクトでも実行できるように RENOVATE_EXTRA_FLAGS--onboarding=true を追加します。

          RENOVATE_EXTRA_FLAGS: --onboarding=true hoge/sample1 hoge/sample2
      
  5. GitLab CI ファイルを作成します。

    作成した Renovate-Runner のプロジェクトに .gitlab-ci.yml を作成します。

    Renovate-Runner-Clone を include して パイプラインがスケジュールで実行されるようにします。

    
        include:
          - project: '$CI_PROJECT_NAMESPACE/renovate-runner-clone'
            file: '/templates/renovate.gitlab-ci.yml'
    
        renovate:
          rules:
            - if: '$CI_PIPELINE_SOURCE == "schedule"'
    
    
  6. スケジュールを設定します。

    1. CI/CD > Schedules で renovate を実行するスケジュールを設定します。

以上、基本的な設定内容です。
これで設定したスケジュールのタイミングで renovate が実行されて依存関係の更新があれば自動的にマージリクエストが作成されます。

option 設定内容

config.js でオプションを設定

congfig.js を作成して renovate が準備しているさまざまなオプションを設定してより細かな動きを設定できます。

詳細は公式ドキュメントを参照してください。

現在、弊社では以下のような設定内容にしています。

    module.exports = {
        // renovate が作成した MRに
        // 任意のラベルを指定
        "labels": ["renovateBot"],
        // 作成される MR の target branch を指定
        "baseBranches": ["vulnerability/main"],
        // フロントメンバーをアサイン
        "assignees": [
            "@kaori",
            "@yuping",
            "@nako.n"
        ],
        // アサインされる人は1人
        "assigneesSampleSize": 1
    }

baseBranches は renovate を実行する前に、事前に作成しておく必要があります。
renovate/hoge という形式でブランチを作成すると renovate 実行時に削除されるので注意です。

実行スケジュールは、config.js で設定、管理もできそうです。

上記設定して、作成されたマージリクエストはこんな感じです。

img_mr.png

その他追加で設定したこと

依存関係の更新頻度は結構多いので、少しでも確認工数を減らし、自動化するために、今、追加で設定しているのが、
devdepencies の メジャーバージョン以外の更新の自動マージです。

セマンティック・バージョニング に則っていれば、メジャーバージョン以外の更新は互換性のない更新はないはずですが、一部則っていないものもあるようなので、注意してください。

更新後は、すぐに修正が入る場合もあるので、3日待ってから自動マージする設定にしています。

設定内容はこんな感じです。

"packageRules": [
    {
      "matchUpdateTypes": ["minor", "patch", "pin", "digest"],
      "matchDepTypes": ["devDependencies"],
      "automerge": true
    }
  ]

他にもたくさんの option があるので、プロジェクトにあうものを採用してカスタマイズしてみてください。

最後に

今回は依存関係をすでに使用しているプロジェクトに導入したので、最初に作成されるMRの数もとても多かったです。また、最初ということもあって、一つ一つの MR の詳細を確認しながら進めました。バージョン更新は怠っていたので、バージョン更新に伴う変更対応の確認や追加対応に結構時間がかかりました。。。

更新対応をしていない既存のプロジェクトに導入してしまうと時間コストがとてもかかるので、
新規で立ち上げるプロジェクトに導入して、最初からこまめなバージョン更新を行なっていく方が良さそうです。

導入してしまえば、あとは自動検知してくれるので手動で更新管理をしなくていいのはやっぱり大きなメリットだと感じました。
また、依存関係単位で MR ができるので更新内容が管理しやすいのも renovate を使うメリットかと思います。

ちなみに GitHub だと脆弱性を伴う更新の場合に vulnerabilityAlerts という renovate の option を使うと label を変えることができたり、設定を分けることができるようです。これができればこの MR は優先的に対応するなどとうまく使えそうですが、GitLab ではこの option が使えないようで。。(もし「GitLab でも使う方法があるよ!」って方がいたら教えてください><) renovate が GitLab でも使用できるようにアップデートの開発をしてくれることを願っています。


現在 EDOCODE では、エンジニア・デザイナー・プロダクトマネジャーを募集しています。
ご興味のある方は、こちらの採用ページも是非ご覧ください。
https://go.edocode.co.jp/jobs

9
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
1