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
良いテストとは何か:持続可能で保守性の高いテストを書く
Search
picopico
October 09, 2023
Programming
16
5.7k
良いテストとは何か:持続可能で保守性の高いテストを書く
PHPカンファレンス2023の登壇資料です。
https://fortee.jp/phpcon-2023/proposal/10143d00-ca44-4db1-aeb6-b618c423b646
picopico
October 09, 2023
Tweet
Share
More Decks by picopico
See All by picopico
PHP 8.4がリリース! あなたはもうアップデートしましたか?
picopico
0
600
PHPとFluentdで実現するリアルタイムログ分析
picopico
2
440
2023 State of DevOps Report」簡易ピックアップ
picopico
0
130
トーク力は一生役に立つよ
picopico
1
680
伝え方で変わるLTの世界
picopico
3
1.4k
エラー処理関数を完全に理解する
picopico
0
160
一日30回リリースを可能にするpixiv開発
picopico
6
3.1k
Other Decks in Programming
See All in Programming
AIによる開発の民主化を支える コンテキスト管理のこれまでとこれから
mulyu
3
510
dchart: charts from deck markup
ajstarks
3
1k
プロダクトオーナーから見たSOC2 _SOC2ゆるミートアップ#2
kekekenta
0
230
AIエージェントのキホンから学ぶ「エージェンティックコーディング」実践入門
masahiro_nishimi
6
690
コントリビューターによるDenoのすゝめ / Deno Recommendations by a Contributor
petamoriken
0
210
OCaml 5でモダンな並列プログラミングを Enjoyしよう!
haochenx
0
150
組織で育むオブザーバビリティ
ryota_hnk
0
180
MDN Web Docs に日本語翻訳でコントリビュート
ohmori_yusuke
0
660
疑似コードによるプロンプト記述、どのくらい正確に実行される?
kokuyouwind
0
390
CSC307 Lecture 05
javiergs
PRO
0
500
CSC307 Lecture 07
javiergs
PRO
1
560
AI によるインシデント初動調査の自動化を行う AI インシデントコマンダーを作った話
azukiazusa1
1
750
Featured
See All Featured
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
61
52k
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
57
GitHub's CSS Performance
jonrohan
1032
470k
Discover your Explorer Soul
emna__ayadi
2
1.1k
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
340
BBQ
matthewcrist
89
10k
It's Worth the Effort
3n
188
29k
Building an army of robots
kneath
306
46k
Effective software design: The role of men in debugging patriarchy in IT @ Voxxed Days AMS
baasie
0
230
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
0
190
Site-Speed That Sticks
csswizardry
13
1.1k
Information Architects: The Missing Link in Design Systems
soysaucechin
0
780
Transcript
良いテストとは何か: 持続可能で保守性の⾼いテストを書く @picopico_dev
テスト、書いていますか?
「良い」テスト、書いていますか?
4 会社 ピクシブ株式会社 経歴 2023年4⽉ 新卒⼊社 業務 Web API設計/PHP .
移⾏ picopico @picopico_dev
⽬次 1. なぜ良いテストが必要なのか 2. 良いテストの指標 3. 良いテストの書き⽅
⽬次 1. なぜ良いテストが必要なのか 2. 良いテストの指標 3. 良いテストの書き⽅
前提:テストは書くべき
テストを書く恩恵 • 機能変更‧リファクタリングしやすい • 素早いフィードバックによる⾼速な開発 • 優れたドキュメンテーション • etc…
テストの質が悪いと‧‧‧? • テストを修正しづらい • すぐテストが壊れる • テストの実⾏が終わらない • たまに原因不明で落ちる •
etc…
コードは資産ではなく負債 コードが多いほど、保守‧運⽤コストがかかる =書かれたテストはゼロコストではない
⽬次 1. なぜ良いテストが必要なのか 2. 良いテストの指標 3. 良いテストの書き⽅
「良い単体テストを構成する4本の柱」 • リグレッションへのセーフティネット • リファクタリング耐性 • 迅速なフィードバック • 保守のしやすさ 「単体テストの考え⽅/使い⽅」p.96
「単体テストを早期に⾏う利点」 • 瞬間的な満⾜感 • モジュール性‧再利⽤性の向上 • リファクタリング‧セーフネット • ドキュメンテーション 「The
Advantages of Unit Testing Early」- Google Testing Blog (https://testing.googleblog.com/2009/07/by-shyam-seshadri-nowadays-when-i-talk.html)
良いテスト =価値の⾼いテスト シンプルに‧‧‧
価値=機能÷コスト
価値=機能÷コスト
コードが正しいことを保証すること 半分間違い
テストの機能 フィードバックループの構築 ドキュメンテーション +
テストの機能 フィードバックループの構築 ドキュメンテーション +
フィードバックループの構築 コードの変更 テスト リリース
シフトレフト
低い⽋陥コストでバグを修正できる →素早いリリースが可能になる →持続可能で保守性の⾼いプロダクトに
テストの機能 フィードバックループの構築 ドキュメンテーション +
ドキュメンテーション • 信頼度が⾼い • Howをコードで⽰している
信頼度が⾼い システム ⽂書 コメント テスト
価値=機能÷コスト
テストのコスト 実装コスト 保守コスト 運⽤コスト + +
テストのコスト 実装コスト 保守コスト 運⽤コスト + +
実装コスト • フレームワークの導⼊ • テストの作成 • CIへの組み込み • 学習
実装コスト テストコードはプロダクションコードより多い
テストのコスト 実装コスト 保守コスト 運⽤コスト + +
保守コスト • フレームワークのアップデート • コード変更時のテストの修正
テストのコスト 実装コスト 保守コスト 運⽤コスト + +
運⽤コスト • テストの実⾏ • CIサーバーの運⽤
価値=機能÷コスト
フィードバックループの構築 実装コスト ドキュメンテーション 運⽤コスト 保守コスト 価値 = ÷
⽬次 1. なぜ良いテストが必要なのか 2. 良いテストの指標 3. 良いテストの書き⽅
良いテストを書くには • 正確なフィードバック • ⾼速なフィードバック • 理解しやすいテスト • テストする価値の⾼いシステムをテストする
良いテストを書くには • 正確なフィードバック • ⾼速なフィードバック • 理解しやすいテスト • テストする価値の⾼いシステムをテストする
正確なフィードバック • 機能が正しく実装されているとき →テストが通る • 機能が正しく実装されていないとき →テストが落ちる
正確なフィードバック 機能が正しくない 機能が正しい テストが通らない 真陰性 偽陽性 テストが通る 偽陰性 真陽性
正確なフィードバック コードの変更 テスト リリース 偽陽性
ホワイトボックステスト • ソフトウェアが内部的に⾏っていることを検証する • Howに依存するため、リファクタリング耐性が低い
ブラックボックステスト • ソフトウェアの振る舞いのみを検証する • Whatに依存するため、リファクタリング耐性が⾼い
正確なフィードバック コードの変更 テスト リリース 偽陰性
偽陰性を減らす • ロジックが正しく動くか • コンポーネントが結合された状態で動くか
テストピラミッド E2E Integration Unit
良いテストを書くには • 正確なフィードバック • ⾼速なフィードバック • 理解しやすいテスト • テストする価値の⾼いシステムをテストする
⾼速なフィードバック コードの変更 テスト リリース できるだけ速く
テストピラミッド E2E Integration Unit
テストサイズ 機能 Small Medium Large ネットワークアクセス No localhost only Yes
データベース No Yes Yes ファイルシステムアクセス No Yes Yes 外部システムの利用 No Discouraged Yes マルチスレッド No Yes Yes スリープ文 No Yes Yes システムプロパティ No Yes Yes 時間制限 (秒) 60 300 900+ 「Test Sizes」- Google Testing Blog (https://testing.googleblog.com/2010/12/test-sizes.html)
良いテストを書くには • 正確なフィードバック • ⾼速なフィードバック • 理解しやすいテスト • テストする価値の⾼いシステムをテストする
理解しやすいテスト • AAAパターン ◦ Arrange - 準備 ◦ Act -
実⾏ ◦ Assert - 確認 • テストケースと振る舞いを対応させる • ⼀度に⼀つの振る舞いを検証する
良いテストを書くには • 正確なフィードバック • ⾼速なフィードバック • 理解しやすいテスト • テストする価値の⾼いシステムをテストする
テストする価値の⾼いシステム • コアドメインに近い • ロジックが複雑である
テストする価値の低いシステム • 単発のスクリプト • 書き直した⽅が早い • ロジックをほぼ持たない
テスタビリティについて
フィードバックループの構築 実装コスト ドキュメンテーション 運⽤コスト 保守コスト 価値 = ÷
実装コスト =テスト対象システムで決まる
Class A Class C Class B Class D
DIとテストダブル • 依存をコンストラクタで注⼊する • テスト時には依存クラスをテストダブルに置き換える
おわり