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.4k
良いテストとは何か:持続可能で保守性の高いテストを書く
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
97
PHPとFluentdで実現するリアルタイムログ分析
picopico
2
320
2023 State of DevOps Report」簡易ピックアップ
picopico
0
110
トーク力は一生役に立つよ
picopico
1
610
伝え方で変わるLTの世界
picopico
3
1.3k
エラー処理関数を完全に理解する
picopico
0
130
一日30回リリースを可能にするpixiv開発
picopico
6
2.8k
Other Decks in Programming
See All in Programming
Unlock the Potential of Swift Code Generation
rockname
0
250
Vibe Codingをせずに Clineを使っている
watany
17
6.3k
地域ITコミュニティの活性化とAWSに移行してみた話
yuukis
0
240
Boost Your Performance and Developer Productivity with Jakarta EE 11
ivargrimstad
0
1.6k
ウォンテッドリーの「ココロオドル」モバイル開発 / Wantedly's "kokoro odoru" mobile development
kubode
1
130
これだけは知っておきたいクラス設計の基礎知識 version 2
masuda220
PRO
24
6.4k
「”誤った使い方をすることが困難”な設計」で良いコードの基礎を固めよう / phpcon-odawara-2025
taniguhey
0
140
Lambda(Python)の リファクタリングが好きなんです
komakichi
3
200
AWSで雰囲気でつくる! VRChatの写真変換ピタゴラスイッチ
anatofuz
0
160
リアルタイムレイトレーシング + ニューラルレンダリング簡単紹介 / Real-Time Ray Tracing & Neural Rendering: A Quick Introduction (2025)
shocker_0x15
1
300
Amazon CloudWatchの地味だけど強力な機能紹介!
itotsum
0
160
スモールスタートで始めるためのLambda×モノリス(Lambdalith)
akihisaikeda
2
280
Featured
See All Featured
The Invisible Side of Design
smashingmag
299
50k
StorybookのUI Testing Handbookを読んだ
zakiyama
29
5.6k
Raft: Consensus for Rubyists
vanstee
137
6.9k
GraphQLの誤解/rethinking-graphql
sonatard
71
10k
Principles of Awesome APIs and How to Build Them.
keavy
126
17k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
5
550
Site-Speed That Sticks
csswizardry
5
490
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
30
2.3k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
2.9k
Why Our Code Smells
bkeepers
PRO
336
57k
The Straight Up "How To Draw Better" Workshop
denniskardys
232
140k
RailsConf 2023
tenderlove
30
1.1k
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とテストダブル • 依存をコンストラクタで注⼊する • テスト時には依存クラスをテストダブルに置き換える
おわり