Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
AI開発を加速するためにテスト戦略を言語化した
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
yoshihiro shu
May 20, 2026
Programming
110
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
AI開発を加速するためにテスト戦略を言語化した
yoshihiro shu
May 20, 2026
More Decks by yoshihiro shu
See All by yoshihiro shu
3プロトコルを実現するconnect-go / Fukuoka.go#20
yoshihiro_shu
1
390
Other Decks in Programming
See All in Programming
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
150
Oxlintのカスタムルールの現況
syumai
6
1.1k
Claspは野良GASの夢をみるか
takter00
0
210
技術的負債解消で開発者の未来を開く- AIの力でコード刷新
kmd2kmd
0
120
さぁV100、メモリをお食べ・・・
nilpe
0
150
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
610
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
570
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
370
AI時代のUIはどこへ行く?その2!
yusukebe
22
7.5k
「AIで開発し、AIを届ける」をEvalでつなぐ 〜AIネイティブに始めるプロダクト開発の実践〜 / Connecting "Develop with AI, deliver AI" with Eval
rkaga
4
5.4k
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
390
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
300
Featured
See All Featured
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
Building a Scalable Design System with Sketch
lauravandoore
463
34k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
A designer walks into a library…
pauljervisheath
211
24k
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
200
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
The Curse of the Amulet
leimatthew05
2
13k
The Anti-SEO Checklist Checklist. Pubcon Cyber Week
ryanjones
0
170
Documentation Writing (for coders)
carmenintech
77
5.4k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
Building Adaptive Systems
keathley
44
3.1k
Transcript
AI開発を加速するために テスト戦略を言語化した Go Connect #13 — 2026/05/20 朱 義宏 /
GMOペパボ 1
自己紹介 朱 義宏 GMOペパボ ロリポップ・ムームードメイン事業部 ロリポップ! 固定IPアクセス 趣味 GWにスリランカに行ってきました ウイスキーが好き
X: @yoshihiro_shu AI時代のGoテスト戦略 2
None
背景: AIエージェントがPRを量産する時代になった AI時代のGoテスト戦略 4
課題: 「正しさ」を証明する基準が言語化されていない PRは量産されるが、ロジックが正しいことをレビューするコストが高い 実装ごとに、正しさを担保するテストにばらつきがある テストはあっても、ロジックの正しさをテスト I/O だけで判断できない → 結局、ロジックが正しいかどうかは 毎回コードを読み解いて判断するしかない
根本原因: 「何を見れば正しいと言えるか」の基準そのものが言語化されていない AI時代のGoテスト戦略 5
2つのプロダクト課題 ① データ遷移の整合性 似たようなユースケースでも、生成されるデータが違う 例: 新規契約 / 二回目以降の新規契約 で発行レコードや適用される時刻が異なる ②
日時依存のビジネスロジック 実行時刻によって結果が変わる 例: 月末に契約すると契約期間が翌月末まで延びる AI時代のGoテスト戦略 6
テストがほとんどシナリオテストに集約されていた テストピラミッドの「結合テスト」: Go サーバー + DB を起動し、外部サービスはモック化して 一連のフローをAPI単位でテストを行っている。 担保していたこと: API
レスポンス(ステータス・メッセージ内容) DB の状態変化(レコードの生成・論理削除) 日時・金額計算(契約期間・請求金額) 外部システムへの副作用(メール送信・リソースの作成) AI時代のGoテスト戦略 7
解決案: テストによって責務を分ける シナリオテスト 結合テスト層 確認すること 期待通りのレコードが ⽣成・削除されているか ユースケーステスト サービス単位 確認すること
契約期間・価格が 期待通りに算出されるか f(x) 単体テスト 関数単位 確認すること 関数の 振る舞いが変わらないか AI時代のGoテスト戦略 8
シナリオテスト → 「データ遷移」だけを見る 保証すること: ユースケースに応じて、期待通りのレコードやリソースが生成・削除されているか 検証しないこと: 日時によって結果が異なるビジネスロジック AI時代のGoテスト戦略 9
ユースケーステスト → 「日時・価格計算」を固定日時で検証 する 保証すること: 日時依存ロジック(契約期間・課金額)が期待通りに算出されるか 検証しないこと: DBへのレコード生成・削除 AI時代のGoテスト戦略 10
単体テスト → 「振る舞いの不変性」を守る 保証すること: 関数の入出力が変わらないこと リファクタリングなどで振る舞いが壊れていないことの確認 意図しないロジックの変更の検知 AI時代のGoテスト戦略 11
結果: テストでロジックの正しさが判断できるようになった テストの input / output を見るだけでロジックの正しさを判断できる → コードを読み解く必要がなくなった テストケースの漏れ
を防ぎやすくなった → 責務が分かれたことで、各層の網羅性が見えやすい レビューに 別の観点 を考える余裕ができた → 認知負荷が下がり、設計・性能などにも目が向く AI時代のGoテスト戦略 12
まとめ 今回考えたのは「大量のPRをマージしてもシステムが壊れない仕組み」だけ レビューには本来、コーディングルール・セキュリティ・パフォーマンスなど多くの観点がある → テストの責務を言語化したのは、その第一歩 → 同じように観点ごとに言語化していきたい AI時代のGoテスト戦略 13