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.3k
良いテストとは何か:持続可能で保守性の高いテストを書く
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とFluentdで実現するリアルタイムログ分析
picopico
2
290
2023 State of DevOps Report」簡易ピックアップ
picopico
0
100
トーク力は一生役に立つよ
picopico
1
600
伝え方で変わるLTの世界
picopico
3
1.2k
エラー処理関数を完全に理解する
picopico
0
120
一日30回リリースを可能にするpixiv開発
picopico
6
2.8k
Other Decks in Programming
See All in Programming
color-scheme: light dark; を完全に理解する
uhyo
4
370
SpringBoot3.4の構造化ログ #kanjava
irof
2
1k
富山発の個人開発サービスで日本中の学校の業務を改善した話
krpk1900
4
390
CDK開発におけるコーディング規約の運用
yamanashi_ren01
2
130
2024年のkintone API振り返りと2025年 / kintone API look back in 2024
tasshi
0
220
How mixi2 Uses TiDB for SNS Scalability and Performance
kanmo
37
14k
Amazon S3 TablesとAmazon S3 Metadataを触ってみた / 20250201-jawsug-tochigi-s3tables-s3metadata
kasacchiful
0
170
Multi Step Form, Decentralized Autonomous Organization
pumpkiinbell
1
750
Unity Android XR入門
sakutama_11
0
160
Kubernetes History Inspector(KHI)を触ってみた
bells17
0
230
定理証明プラットフォーム lapisla.net
abap34
1
1.8k
Java Webフレームワークの現状 / java web framework at burikaigi
kishida
9
2.2k
Featured
See All Featured
A Tale of Four Properties
chriscoyier
158
23k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
366
25k
GraphQLとの向き合い方2022年版
quramy
44
13k
What's in a price? How to price your products and services
michaelherold
244
12k
Navigating Team Friction
lara
183
15k
How STYLIGHT went responsive
nonsquared
98
5.4k
Six Lessons from altMBA
skipperchong
27
3.6k
GitHub's CSS Performance
jonrohan
1030
460k
A designer walks into a library…
pauljervisheath
205
24k
The Cost Of JavaScript in 2023
addyosmani
47
7.3k
Music & Morning Musume
bryan
46
6.3k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
129
19k
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とテストダブル • 依存をコンストラクタで注⼊する • テスト時には依存クラスをテストダブルに置き換える
おわり