5
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

株式会社トラストバンク・プロダクト開発部の @hiroooo23 です。
この記事は トラストバンク Advent Calendar 2024 の16日目の記事です。

トラストバンクには2024年の8月に入社。
現在はふるさとチョイスのフロントエンドの開発を担当しています。

AIがコードレビュー?

以前チーム内でコードレビュー用のAIツールがあるという話を聞き、ついにそんな時代になったのか!と驚きました。

コーディング規約やレビュー観点をあらかじめ設定しておいて、一部自動でチェックしてくれる仕組みがあれば便利そうです。

「実際どこまで指摘してくれるのか?」「実務で使えそうか?」など興味を持ったので試してみました。

今回確かめたいこと

設定したコーディング規約などに沿って、AIが正しくコードレビューをしてくれるか。(セキュリティやコストは今回調べない)

確かめる方法

テスト用のリポジトリで、コーディング規約に反する問題のあるコードをAIツールにレビューしてもらう

準備

レビュー対象になるコードを用意する

すぐに作れるNext.jsの公式サイトのcreate-next-appを使いました。

AIツールを決める

今回はCodeRabbitのOSSである「ai-pr-review」というツールを使いました。しっかりとツールを選定をしたというわけでなく、

・関連する記事が多い
・Github Actionの設定するだけなら導入ハードルが低そう

という理由でとりあえず選びました。

:warning:ただしCodeRabbitのサイトは「Pro版」の案内をしているので注意です!

OpenAI APIとGithubの設定

「ai-pr-review」はOpenAIのAPIを使うので、それぞれ設定が必要です。

  1. OpenAIのAPIクレジットを購入する
    以前は無料クレジットがあったようですが、今は最低5ドルのクレジットを購入する必要があるようです。(クレジットを購入せずに利用すると自分はGithub Actionでエラーになりました...)

  2. APIキーを入手
    クレジットを購入後、API keysタブでAPIキーを入手できます。

  3. GithubにTokenを設定する
    GitHubのリポジトリ設定でOPENAI_API_KEYに取得したTokenを設定します。
    スクリーンショット 2024-12-16 23.09.48.png

Github Actionの設定

最後に.github/workflows配下で設定ファイルを作成します。
最終的にできたファイルが下記の通りです!

.github/workflows/code-rabbit.yaml
name: Code Review

permissions:
  contents: read
  pull-requests: write

on:
  pull_request:
  pull_request_review_comment:
    types: [created]

concurrency:
  group:
    ${{ github.repository }}-${{ github.event.number || github.head_ref ||
    github.sha }}-${{ github.workflow }}-${{ github.event_name ==
    'pull_request_review_comment' && 'pr_comment' || 'pr' }}
  cancel-in-progress: ${{ github.event_name != 'pull_request_review_comment' }}

jobs:
  review:
    runs-on: ubuntu-latest
    steps:
      - uses: coderabbitai/ai-pr-reviewer@latest
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
          OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
        with:
          debug: false
          review_simple_changes: false
          review_comment_lgtm: false
          openai_light_model: gpt-4
          openai_heavy_model: gpt-4
          language: ja-JP
          system_message: |
            あなたは @coderabbitai(別名 github-actions[bot])で、OpenAIによって訓練された言語モデルです。
            あなたの目的は、非常に経験豊富なフロントエンドエンジニアとして機能し、下記コーディング規約に基づいて、コードの一部を徹底的に日本語でレビューしてください。
            - HTMLに不要な処理は入れない
            - インラインCSSは使用しない
            - HTMLタグに対して過不足な属性がないか確認する
            - "mv"というクラスがない場合はimgタグにloading="lazy”属性をつけ、altがあるか確認する
            - aタグにはtarget=_blankをつける
            - typescriptを用いた記述については下記を確認すること
              - 型でエラーが起きていないか
              - ロジックが間違っている、もしくは過不足がないか
              - 仕様に関するコメントと関数名、処理内容に乖離がないか

  • openai_light_model,openai_heavy_modelでchatGPTのモデルを指定する
  • languageで日本語を設定する(ja-JP
  • system_messageにコーディング規約やレビュー観点を記入する
- HTMLに不要な処理は入れない
- インラインCSSは使用しない
- HTMLタグに対して過不足な属性がないか確認する
- "mv"というクラスがない場合はimgタグにloading="lazy”属性をつけ、altがあるか確認する
- aタグにはtarget=_blankをつける
- typescriptを用いた記述については下記を確認すること
- 型でエラーが起きていないか
- ロジックが間違っている、もしくは過不足がないか
- 仕様に関するコメントと関数名、処理内容に乖離がないか

いざ、PR

お手並み拝見ということで、色々と問題のあるHTMLとTypeSciptファイルをプッシュしてPRを出してみました。

実際のレビュー画面はこんな感じでした。

HTMLのレビュー

chatGPTのプロンプト(.github/workflows/code-rabbit.yamlsystem_messageに書いたこと)に入れたことは全て指摘してくれました!また指示にないidの重複も指摘できてます。

  • インラインCSSは使用しない → :ok_hand:指摘してくれた
    スクリーンショット 2024-12-16 23.27.24.png

  • 条件を満たさないimgタグの属性 → :ok_hand:指摘してくれた
    スクリーンショット 2024-12-16 23.27.34.png

  • aタグにはtarget=_blank → :ok_hand:指摘してくれた
    スクリーンショット 2024-12-16 23.27.44.png

  • idの重複 → :ok_hand:指摘してくれた
    スクリーンショット 2024-12-16 23.28.37.png

  • href="javascript:void(0)" → :frowning2:他の方法の提案はしてくれなかった
    上記はリンクの遷移を意図的になくす処理ですが、jsで制御しなくてもaタグにせず、カーソル機能をCSSで実装する方法もあります。今回そのような提案はされませんでした...

TypeSciptのレビュー

明らかにロジックが間違っている部分は指摘してくれました!またany型になっていることや簡単な命名法の部分も指摘、提案してくれています。

  • ロジックのミス(true,falseが逆) → :ok_hand:指摘してくれた
    スクリーンショット 2024-12-16 23.52.44.png

  • 型の命名法やany型について → :ok_hand:指摘してくれた
    スクリーンショット 2024-12-16 23.53.43.png
    スクリーンショット 2024-12-16 23.52.03.png

まとめ・感想

あまり多くのパターンは試せませんでしたが、自分が想像以上に適切にレビューしてくれました。コーディング規約・レビュー方針をしっかり決めておけば、AIレビューの設定もスムーズかもしれません。

メモ:要修正・調査事項

レビューのタイミング調整

今のままだとコミットする度にAIのレビュー処理が走ってしまうのでGithub Actionを調整が必要です。

コストの計測

今回はパフォーマンスに着目しましたが、使用するchatGPTのモデルによって料金も変わるようなので本来は詳細な調査が必要そうです。
スクリーンショット 2024-12-17 0.15.55.png

セキュリティ面

よくある話ですがAIにコードを学習させていいのか?という部分は当然考える必要がありますね。

最後に

トラストバンクでは一緒に働く仲間を絶賛募集中です!
ご興味を持たれた方はぜひお気軽にご連絡ください!

参考記事

5
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
5
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?