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
動作する読みやすいE2Eを目指して/Aim for readable E2E
Search
Culvert
October 16, 2024
Technology
1
130
動作する読みやすいE2Eを目指して/Aim for readable E2E
XP祭り2024の発表資料です。
Culvert
October 16, 2024
Tweet
Share
More Decks by Culvert
See All by Culvert
受け入れテスト駆動開発で不確実性に段階的に対処する/Addressing Uncertainty Incrementally with Acceptance Test-Driven-Development
culvert
4
1.5k
ソフトウェアの設計を学び、メンテナンスしやすいテストを作ろう / Learn software design, Create tests that are easy to maintain
culvert
3
2.6k
私が経験したアジャイルテスト
culvert
4
1.4k
NaITE__32_First_ML.pdf
culvert
0
380
naite31_jstqb_tm
culvert
0
530
地域の子どもを地域で育てる
culvert
0
210
モヤモヤと向き合う
culvert
0
570
デブサミに行ってきた話
culvert
0
130
Other Decks in Technology
See All in Technology
Liquid Glass革新とSwiftUI/UIKit進化
fumiyasac0921
0
140
生成AIでwebアプリケーションを作ってみた
tajimon
2
130
本当に使える?AutoUpgrade の新機能を実践検証してみた
oracle4engineer
PRO
1
120
2年でここまで成長!AWSで育てたAI Slack botの軌跡
iwamot
PRO
2
410
Agentic DevOps時代の生存戦略
kkamegawa
0
1k
AIのAIによるAIのための出力評価と改善
chocoyama
1
520
AIの最新技術&テーマをつまんで紹介&フリートークするシリーズ #1 量子機械学習の入門
tkhresk
0
130
より良いプロダクトの開発を目指して - 情報を中心としたプロダクト開発 #phpcon #phpcon2025
bengo4com
1
390
PHPでWebブラウザのレンダリングエンジンを実装する
dip_tech
PRO
0
180
解析の定理証明実践@Lean 4
dec9ue
0
100
Welcome to the LLM Club
koic
0
140
実践! AIエージェント導入記
1mono2prod
0
150
Featured
See All Featured
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
GraphQLとの向き合い方2022年版
quramy
46
14k
Build The Right Thing And Hit Your Dates
maggiecrowley
36
2.8k
A designer walks into a library…
pauljervisheath
206
24k
Code Reviewing Like a Champion
maltzj
524
40k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
107
19k
Rebuilding a faster, lazier Slack
samanthasiow
81
9k
How GitHub (no longer) Works
holman
314
140k
4 Signs Your Business is Dying
shpigford
184
22k
Art, The Web, and Tiny UX
lynnandtonic
299
21k
Speed Design
sergeychernyshev
31
1k
The Invisible Side of Design
smashingmag
299
51k
Transcript
動作する読みやすい E2Eを目指して 2024/9/28 XP祭り
2 藤原 考功(Takanori Fujiwara) ・株式会社ユーザベースの社員(テストエンジニア) ・XP祭り実行委員 ・JSTQB(Japan Software Testing Qualification
Board)技術委員 自己紹介 https://www.shoeisha.co.jp/book/detail/9784798186061
3 E2Eテスト(以下、E2E)に対する改善活動 今日お話しすること
4 • 画面やAPIなどの仕様を、 利用者の立場で記述する • 上記に、動作を確認するための手順が 自動テストとして紐付いている 本セッションにおける「E2E」
5 • 動作するドキュメント ◦ 利用者の立場から見た仕様が書かれている ◦ 自動テストとして動かすことができる 本セッションにおける「E2E」 特に、最新の仕様がタイムリーに反映されていることが重要だと思っています
6 • 仕様を理解できる記述になっている ◦ 利用者の立場から見た仕様が書かれている • 安定して動作する ◦ 自動テストとして動かすことができる 「E2E」が備えていてほしい要素
発表の都合上、後者の「安定して動作する」の方を先に話します
7 • GaugeとSelenideを採用 • 自然言語で記述し、テストコードと紐付ける 私たちのチームの場合
8 紐付けの例
動作するE2E | 01 | 9
10 ・まずは最低限動作するコードを書く ・テストがGreenな状態を保ったまま コードを綺麗にする テスト駆動開発の考え方
11 ・まず安定して動作することが大事 ・動作しない(特に不安定な)テストコードは 余計なストレスを生む ・安定して動くから安心して試行錯誤できる E2Eにも同じことが言えるはず
12 ・安定しない原因を愚直に調べる ・安易なリトライもなるべくやめる どうしたら安定するのか
13 ・画面を開く ・画面の描画が終わるまで待つ ・画面内の要素を検証する 例えば、「待ち」を改善する
14 ・画面を開く ・画面の描画が終わるまで待つ←ここが抜けがち ・画面内の要素を検証する 例えば、「待ち」を改善する
読みやすいE2E | 02 | 15
16 テストコードは常に具体的な手順として 細かく書く必要があるので、 記述量が多くなりがち E2Eが読みづらくなってしまう理由 その1
17 ・ログイン画面を開く ・ログイン画面が表示されるまで待つ ・ユーザー名に「username」を入力する ・パスワードに「password」を入力する ・「ログイン」ボタンを押下する 記述量(手数)が多い例
18 対策:1行に置き換えて隠す
19 ・記述しない...は無理なので、 何らかの形で構造化する ・インデントする、色を分ける、 ファイルを分ける etc… 記述量への対策
20 ・具体的な事実しか書かれておらず、 仕様そのものや、なぜその仕様になったか といった情報が欠落している E2Eが読みづらくなってしまう理由 その2
21 ・上映開始時刻が21:30である場合、 料金として1,500円を表示する 具体的な事実しか書かれていない例 仕様が読み取れない!!
22 対策:仕様がわかる記述に置き換える
まとめに替えて | 03 | 23
・安定して動作するE2Eを手に入れるために、 安定しない原因を少しずつ潰す ・綺麗で読みやすいE2Eを手に入れるために、 具体的(すぎる)記述に少しずつ手を入れる 24 動作する読みやすいE2Eを目指して 結局、こまめな片付けが大事ってことなんだと思います