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
ソフトウェアの設計を学び、メンテナンスしやすいテストを作ろう / Learn software...
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Culvert
December 09, 2023
Technology
3
2.7k
ソフトウェアの設計を学び、メンテナンスしやすいテストを作ろう / Learn software design, Create tests that are easy to maintain
2023/12/9 ソフトウェアテスト自動化カンファレンス2023の発表資料です。
Culvert
December 09, 2023
Tweet
Share
More Decks by Culvert
See All by Culvert
動作する読みやすいE2Eを目指して/Aim for readable E2E
culvert
1
160
受け入れテスト駆動開発で不確実性に段階的に対処する/Addressing Uncertainty Incrementally with Acceptance Test-Driven-Development
culvert
5
1.7k
私が経験したアジャイルテスト
culvert
4
1.5k
NaITE__32_First_ML.pdf
culvert
0
410
naite31_jstqb_tm
culvert
0
550
地域の子どもを地域で育てる
culvert
0
230
モヤモヤと向き合う
culvert
0
590
デブサミに行ってきた話
culvert
0
150
Other Decks in Technology
See All in Technology
セキュリティについて学ぶ会 / 2026 01 25 Takamatsu WordPress Meetup
rocketmartue
1
290
制約が導く迷わない設計 〜 信頼性と運用性を両立するマイナンバー管理システムの実践 〜
bwkw
3
870
Mosaic AI Gatewayでコーディングエージェントを配るための運用Tips / JEDAI 2026 新春 Meetup! AIコーディング特集
genda
0
150
顧客との商談議事録をみんなで読んで顧客解像度を上げよう
shibayu36
0
170
10Xにおける品質保証活動の全体像と改善 #no_more_wait_for_test
nihonbuson
PRO
2
200
フルカイテン株式会社 エンジニア向け採用資料
fullkaiten
0
10k
今日から始めるAmazon Bedrock AgentCore
har1101
4
400
プロダクト成長を支える開発基盤とスケールに伴う課題
yuu26
4
1.3k
Sansan Engineering Unit 紹介資料
sansan33
PRO
1
3.8k
CDK対応したAWS DevOps Agentを試そう_20260201
masakiokuda
1
200
会社紹介資料 / Sansan Company Profile
sansan33
PRO
15
400k
クレジットカード決済基盤を支えるSRE - 厳格な監査とSRE運用の両立 (SRE Kaigi 2026)
capytan
6
2.6k
Featured
See All Featured
HDC tutorial
michielstock
1
360
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
2k
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.2k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.3k
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
180
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
A better future with KSS
kneath
240
18k
The Illustrated Guide to Node.js - THAT Conference 2024
reverentgeek
0
250
Design in an AI World
tapps
0
140
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
Color Theory Basics | Prateek | Gurzu
gurzu
0
190
Into the Great Unknown - MozCon
thekraken
40
2.2k
Transcript
ソフトウェアの設計を学び、 メンテナンスしやすいテストを作ろう 2023/12/9 ソフトウェアテスト自動化カンファレンス2023
2 藤原 考功(Takanori Fujiwara) ・ユーザベースの社員(SaaS事業所属のテストエンジニア) ・JSTQB(Japan Software Testing Qualification Board)技術委員
・XP祭り実行委員 自己紹介
3 メンテナンスしやすい状態を作れば、 自ずと無理なく継続的にメンテナンスできる。 それは、メンテナンスしづらい状態で 無理に頑張るよりもきっと価値がある。 はじめに テスト の話 ソフト ウェア
の話
4 ・ソフトウェア品質の測り方のひとつ ・内部品質と呼ばれたりする(顧客からは見えない) ・規格によっていろいろな定義がある メンテナンスのしやすさ≒保守性 ソフト ウェア の話
5 ・自動車や飛行機は部分ごとにメンテナンスができる ・部分の単位では複雑度が低い(≒シンプルな)作りになっている ・ある部分のメンテナンスが他に影響しないよう設計されている (影響すると大変なことになる) 分割できるとメンテナンスしやすい ソフト ウェア の話
6 粒度「大」だけを頑張ってメンテナンスしようとしていた 過去のわたしがイメージする「自動テスト」 粒度 ◯◯テスト 大 画面のテスト(≒E2Eテスト) 中 正直よくわからない (APIのテストとか?具体的なイメージはわかない
...) 小 ユニットテスト (概念は知っているけど、やっぱり具体的なイメージはわかない ...) テスト の話
7 ・大規模なサービスは、多数の「意味のあるまとまり」で構成されていた ・それぞれが責務を持ち、それぞれの「使い方」だけを知っている状態 ・テストは「意味のあるまとまり」とセットで作られていた いまのチームに来て驚いたこと テスト の話 ソフト ウェア の話
8 ・E2Eテスト:外部から見たふるまいを記述 ・ユニットテスト:内部のコンポーネントのふるまいを記述 実際の例 ユニット テスト E2E テスト ユニット テスト
E2E テスト ユニット テスト E2E テスト ※Backend For Frontendの 略。本発表では説明を割愛し ますが、そういう責務がある んだなーと思ってください。 テスト の話 ソフト ウェア の話 フロント エンド BFF(※) バック エンド
9 ・表示に関わる仕様変更:フロントエンドだけ気にすれば済む ・計算ロジックに関わる仕様変更:バックエンドだけ気にすれば済む 実際の例 ※Backend For Frontendの 略。本発表では説明を割愛し ますが、そういう責務がある んだなーと思ってください。
テスト の話 ソフト ウェア の話 ユニット テスト E2E テスト ユニット テスト E2E テスト ユニット テスト E2E テスト フロント エンド BFF(※) バック エンド
10 粒度に応じたテストだけをメンテナンスすれば良いので、無理がない 現在のわたしがイメージする「自動テスト」 粒度 ◯◯テスト 大 サービス全体にまたがるテスト (など) 責務に応じて(柔軟に)設計された、 ソフトウェアの単位に対応するテスト
中 いろいろ 小 ユニットテスト テスト の話
11 ・テスト対象を様々な粒度で捉えられるようになった ・責務に照らして、過不足のないテストを意識するようになった ・メンテナンスのしづらさは、危険を知らせるサインだと思うようになった 責務の概念を学んだ結果 テスト の話 ソフト ウェア の話
12 ・チームで取り組む ・テストを通じて良い設計を考える ・毎日やる 取り組み方 テスト の話 ソフト ウェア の話
13 ・常時ペアプロ、モブプロ ・手を動かして学ぶ、気付く ・教えようとすることで学ぶ、気付く チームで取り組む テスト の話 ソフト ウェア の話
14 ・いきなり完璧な設計をすることは難易度が高い ・テストを起点に、段階的に不確実性を下げる(≒受け入れテスト駆動開発) ・スコープを絞ることができる テストを通じて良い設計を考える テスト の話 ソフト ウェア の話
15 ・習慣になる ・無理なく強度を保つことができる ・違和感に気づきやすくなる 毎日やる テスト の話 ソフト ウェア の話
16 ソフトウェアの設計理論を学び、 実際のソフトウェアの実装に沿ったテストを構築することで メンテナンスのしやすさは格段に上がる。 理論を学ぶ方法は様々あるが、 経験豊富なSWE(ソフトウェアエンジニア)と 密にコミュニケーションできることが望ましい(と私は思います)。 まとめ