7
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

AmazonQにGitHubプロジェクトのissueを任せてPRまで自動で出してもらう

Last updated at Posted at 2024-08-27

まるで魔法のような。

CodeCatalystの機能として、Amazon QによるIssueの自動対応というものがあります。
ノーコード開発でもないのに、もうコードエディタすら開かなくていいんですね。

AmazonQに関しては、「ソフトウェア開発を加速し、企業の内部データを活用するための、生成 AI を活用した極めて有能なアシスタント」とのことです。VScodeに導入すればCopilotのように使うことができます。

今回はこちらの機能を利用して、GitHub上のプロジェクトに対してAmazon QによるIssue対応をしてもらおうと思います。

CodeCatalystの機能なのにGitHubで扱えるの?と思うわけですが、CodeCatalystはGitHubとリンクさせることができます。AmazonQの操作対象はあくまでもCodeCatalystです。
本記事の方法で進めれば最終的にマージなどの作業を行うのはGitHubなので、現在GitHubで管理しているプロジェクトにも移行作業無しでAmazonQさんを問題なく導入できるというわけです。

参考記事

AWS CodeCatalyst にログイン

CodeCatalystへのログインには、AWS Builder IDを使用します。

https://codecatalyst.aws/login からサインアップ(またはサインイン)を行なってログインします。

スクリーンショット 2024-08-27 11.48.48.png

詳しいやり方はワークショップのこちらのページをご覧ください。

こちらのページにも記載がある通り、そのほかのAWSリソースと連携する場合はAWS アカウントで CodeCatalyst に許可を与える必要があるみたいですが、今回は無しで大丈夫でしょう。

スペースを作成

CodeCatalystにおいてスペースとは、会社や部署などの組織であったり、開発者のグループであったりを指します。
「Create space」から作成します。

各項目を入力してください。

スクリーンショット 2024-08-27 12.36.26.png

リージョンは、AmazonQが利用できるものを選ぶ必要があります。
記事執筆現在はオレゴンが利用可能なのでこちらを選択します。

AWS account IDには、請求などを紐づけるAWSアカウントのIDを入力します。

入力ができたらトークンの検証が必要なので、言われた通りに進めましょう。

AI を有効化

スペースの設定(Settings)から、Generative AIを有効にします。
これによりCodeCatalyst内でAmazonQが利用できるようになります。

スクリーンショット 2024-08-27 12.46.07.png

プロジェクトを作成

「Create project」からプロジェクトを作成します。
ここではプロジェクトは、GitHubのリポジトリを参照してリンクさせたいので、GitHubアカウントの接続を行います。

Bring your own code > Link existing repository > GitHub
を選択すると「Connect GitHub」みたいなボタンが出ると思うのでそちらを押すとGitHubのページが開いて接続を行うことができます。

アクセスを許可するリポジトリは、このプロジェクトにリンクさせたいものだけに制限するのが無難かと思います。

完了したらCodeCatalystに戻ります。

スクリーンショット 2024-08-27 12.50.45.png

リポジトリと、CodeCatalystでのプロジェクト名を入力したら「Create project」を押します。

するとプロジェクトのダッシュボード的な画面に移ります。

AmazonQにやってもらうissueを作成

issueはどうやら、CodeCatalystでGitHubのissueまで管理できるわけではなさそうですが、今回は特に問題ありません。
「Create issue」からissueを追加します。

タイトルと内容がそのままAIへのプロンプトとして反映されると思われるため、プロンプトを意識して記入します。

そして、アサインをAmazonQに当てます

これにより、このissueをAmazonQが自動で開発対応してくれます。

以下の「+Assign to Amazon Q」を選択します。
スクリーンショット 2024-08-27 13.07.48.png

↓こうなればOK

スクリーンショット 2024-08-27 13.11.44.png

Amazon Q とのやりとり

issueを作成した後はしばらくAmazonQが頑張っています。
スクリーンショット 2024-08-27 13.13.52.png

しばらくするとissueのコメント欄に、「こんな感じで実装しようと思てるけどええか?」みたいな感じで聞いてきます。
「Proceed」を押せば次のコード生成のステップに進みます。
もしダメだったら「Reply」から返信をしてあげるとまた方針を考え直してくれます。

スクリーンショット 2024-08-27 13.14.54.png

ちなみに今は英語でしか出力されませんが、入力は日本語でも問題ないようです。

GitHub でPRを確認

コード生成までできて、AmazonQがPRを出し終えると、なんとそのPRがGitHubに反映されています。
スクリーンショット 2024-08-27 13.21.57.png

あとはGitHub上でPRを確認してマージするだけです。

AmazonQにやってもらうべきissueとそうでないissue

普段からchatGPTやCopilot、Claudeなどの生成AIを使って開発をしている方ならわかると思いますが、生成してもらったコードの中には当てにならない答えだったり、手動での修正が必要なコードはまだまだ多いかと思います。

そのため当然これも全てのissueを完全にAmazonQに任せられるかといえばそうではなさそうです。

実際、試しにいくつかissueを投げてAmazonQのPRを出してもらい、それらを実行させてみましたが、一部でエラーが発生しました。特に新たに関数や変数を定義したり、ライブラリを追加したりする場合にエラーが見受けられました。
エラーが発生した箇所は手作業で直す必要があります。
しかし、その手作業の修正がもし微量であればトータルで考えるとかなりの時短になるのではないでしょうか

これは私の所感であり持論ですが、
機能を新たに追加するような0→1のタスクはVScode上で作業して、
リファクタや既存の仕様のちょっとした変更などはAmazonQに任せることで大幅に作業効率がUPしそうです。

まとめ

AmazonQによる自動issue対応の方法自体は簡単でした。
「どのissueをAmazonQに任せるべきか」という判断がうまくできるようになれば、めちゃくちゃ使えそうです。

7
8
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
7
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?