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
自動テストについて / Automated Testing
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
mnuma
April 06, 2023
Technology
240
0
Share
自動テストについて / Automated Testing
mnuma
April 06, 2023
More Decks by mnuma
See All by mnuma
セキュリティチェックシートの話 / Security Check Sheet
mnuma
0
34
Datadogで始めるユーザー行動分析 / Getting Started with User Behavior Analysis Using Datadog
mnuma
0
80
Kubernetesの自動アップグレードについて / Upgrading GKE cluster
mnuma
0
220
AWS Auroraのスロークエリを Datadogで扱うまで / How to handle slow_queries_logs in AWS Aurora with Datadog
mnuma
0
980
Googleに学ぶDesign Docs / Learn from Google on Design Docs
mnuma
0
180
Observabilityを実践する / Pragmatic observability
mnuma
2
240
Kubernetes Case Studies #1@Makuake KubeCon NA 2019 Recap
mnuma
0
170
カオスエンジニアリングについてヤホーで調べてきました / Enter the chaos engineering
mnuma
0
130
Chaos Engineering 現状把握 / History Of Chaos Engineering
mnuma
0
370
Other Decks in Technology
See All in Technology
互換性のある(らしい)DBへの移行など考えるにあたってたいへんざっくり
sejima
PRO
0
520
VSCode中心だった自分がターミナル沼に入門した話
sanogemaru
0
900
LLMに何を任せ、何を任せないか
cap120
11
6.9k
ハーネスエンジニアリング×AI適応開発
aictokamiya
3
1.3k
15年メンテしてきたdotfilesから開発トレンドを振り返る 2011 - 2026
giginet
PRO
2
260
バックオフィスPJのPjMをコーポレートITが担うとうまくいく3つの理由
yueda256
1
160
Kubernetesの「隠れメモリ消費」によるNode共倒れと、Request適正化という処方箋
g0xu
0
170
Oracle Cloud Infrastructure:2026年3月度サービス・アップデート
oracle4engineer
PRO
0
320
FASTでAIエージェントを作りまくろう!
yukiogawa
4
190
自分をひらくと次のチャレンジの敷居が下がる
sudoakiy
5
1.7k
出版記念イベントin大阪「書籍紹介&私がよく使うMCPサーバー3選と社内で安全に活用する方法」
kintotechdev
0
140
制約を設計する - 非決定性との境界線 / Designing constraints
soudai
PRO
4
890
Featured
See All Featured
Are puppies a ranking factor?
jonoalderson
1
3.2k
Scaling GitHub
holman
464
140k
Design in an AI World
tapps
0
190
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.2k
The Invisible Side of Design
smashingmag
302
51k
Test your architecture with Archunit
thirion
1
2.2k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
170
Abbi's Birthday
coloredviolet
2
6.2k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.4k
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
210
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
110
Leading Effective Engineering Teams in the AI Era
addyosmani
9
1.8k
Transcript
2023.04.05 Makuake 社内LT @mnuma 自動テストについて
@mnuma タモリ倶楽部が終了してしまって悲しいです。 自己紹介
信頼性の高い自動化テストの実施 開発者が主体となった承認テストの作成・管理、およ び承認テストの容易な複製・修正 「テスト自動化」は ハイパフォーマー達 のプラクティス インプレス出版「LeanとDevOpsの科学」 p.65
自動テストの「信頼性」
None
正しい 間違ってる 成功 OK 偽陰性 失敗 偽陽性 OK テスト結果 コード
テストにおける偽陽性と偽陰性
テストにおける偽陽性と偽陰性 偽陽性: コードが正しいがテスト結果が失敗してしまう。誤検知。 ・脆いテスト (brittle test, fragile test) ・信頼不能テスト (flaky
test) 偽陰性: プロダクトコードが誤っているにもかかわらずテストが成功してしまう。 ・空振り ・カバレッジ不足
https://testing.googleblog.com/2010/12/test-sizes.html テストサイズ における分類
「結合テスト」とは? 連携されるシステム動作全般? 「ユニットテスト」とは? ロンドン学派 vs デトロイト学派 「テストサイズ」 曖昧な概念なので計測可能な定義付けを行ったもの。 テスト範囲で語ると混乱が起きがち
Small Medium Large 単一プロセスで実行されるテスト。 上限: 60秒 単一マシン上で実行されるテスト。 上限: 300秒 制約なし。
上限: 900秒+ Enormous もっとやばいやつ
Small Medium Large 言語の実行環境だけで動かせるテスト コンテナを組み合わせて実行するテスト 本番同等の環境にデプロイして実施するテスト Enormous もっとやばいやつ
「忠実性」 どんどん本番 に近くなる Small Medium Large 単一プロセスで実行されるテスト。 上限: 60秒 単一マシン上で実行されるテスト。
上限: 300秒 制約なし。 上限: 900秒+ Enormous もっとやばいやつ 「スピード」 どんどん 遅くなる 「非決定的」 複雑化し 予測出来なくなる
「忠実性」 どんどん本番 に近くなる Small Medium Large 単一プロセスで実行されるテスト。 上限: 60秒 単一マシン上で実行されるテスト。
上限: 300秒 制約なし。 上限: 900秒+ Enormous もっとやばいやつ 「スピード」 どんどん 遅くなる 「非決定的」 複雑化し 予測出来なくなる より本番に近い状況でテスト可能になる反面、 準備が難しく、動作は遅く、非決定的になりがち。 テスト失敗時分析も難しくなる。
テストのコスパ ✗ ✗ ✗
理想的なテスト
テストピラミッド 70% 20% 10% https://testing.googleblog.com/2015/04/just-say-no-to-more-end-to-end-tests.html くらいの 比率が望 ましい
Manual base Manual base Large Medium Smalll
Manual base Large Medium Smalll 速度 決定性 70% 20% 10%
コスト 忠実性
Inverted pyramid ice cream cone ✗ Hourglass pyramid ✗ ◦
実際には色々な変遷を辿ると思う
Manual base Large Medium Smalll 速度 決定性 70% 20% 10%
コスト 忠実性 サイズダウン 戦略
テスト自動化の 原則
テスト自動化の8原則 5. 自動テストシステムの開発は継続的 におこなうものである 6. 自動化検討はプロジェクト初期から 7. 自動テストで新種のバグが見つかる ことは稀である 8.
「テスト結果の分析」という新たな タスクが生まれる 1. 手動テストはなくならない 2. 手動でおこなって効果のないテス トを自動化しても無駄である 3. 自動テストは書いたことしかテス トしない 4. テスト自動化の効用はコスト削減 だけではない テスト自動化研究会 https://sites.google.com/site/testautomationresearch/test_automation_principle
繰り返し使われるテストのコストを削減 開発アクティビティへの効用 動いたはずの機能が壊れることを発見出来る 手動で実施したほうがテストの品質が高い 記述されたことしかテスト出来ない 運用に時間がかかる 最初から自動化が考慮されてない場合大変 テスト結果分析という新たなタスクが生まれる メリット (Pros)
デメリット (Cons)
手動テストはなくならない ユーザビリティテストなど、そもそも自動化できないテストタイプが存在する。 システムに対してはじめて実行されるテストはテストケース自体の成熟度の観点 から、手動で実施したほうがテスト実行の品質が高いケースが多い。また、自動 化がうまく進行している機能テストの残り数%など、テストを自動化するコスト とベネフィットが釣り合わないケースもある。これらの事情によって、手動で実 施されるテストが無くなることはない。
まとめ 自動テストを行ってハイパフォーマーの仲間入りをしよう 偽陰性 / 偽陽性 でテストの信頼性を意識しよう テストサイズを意識してコスパのいいテストをしよう ピラミッド型を意識したテスト戦略を立てよう 高品質である手動テストを活かせるようにしよう
END