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
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
DPon
July 20, 2024
Programming
0
140
テスト書きたいけど 書けてないのは 何でなんだぜ
DPon
July 20, 2024
Tweet
Share
More Decks by DPon
See All by DPon
つよつよな人の理解の早さを理解する
dznbk
0
120
OpenSearchでレガシーな検索処理の大幅改善をやってやろう
dznbk
2
700
php-fpmのプロセスをコントロールする
dznbk
0
17
Other Decks in Programming
See All in Programming
高速開発のためのコード整理術
sutetotanuki
1
330
Findy AI+の開発、運用におけるMCP活用事例
starfish719
0
2.3k
副作用をどこに置くか問題:オブジェクト指向で整理する設計判断ツリー
koxya
1
550
Oxlintはいいぞ
yug1224
5
1.1k
CSC307 Lecture 06
javiergs
PRO
0
660
Fluid Templating in TYPO3 14
s2b
0
110
公共交通オープンデータ × モバイルUX 複雑な運行情報を 『直感』に変換する技術
tinykitten
PRO
0
200
それ、本当に安全? ファイルアップロードで見落としがちなセキュリティリスクと対策
penpeen
7
2.4k
KIKI_MBSD Cybersecurity Challenges 2025
ikema
0
1.2k
フロントエンド開発の勘所 -複数事業を経験して見えた判断軸の違い-
heimusu
7
2.7k
CSC307 Lecture 02
javiergs
PRO
1
770
re:Invent 2025 トレンドからみる製品開発への AI Agent 活用
yoskoh
0
700
Featured
See All Featured
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
430
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
Hiding What from Whom? A Critical Review of the History of Programming languages for Music
tomoyanonymous
2
380
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.6k
Prompt Engineering for Job Search
mfonobong
0
150
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
560
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
61
52k
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
61
Side Projects
sachag
455
43k
Building the Perfect Custom Keyboard
takai
2
670
Optimising Largest Contentful Paint
csswizardry
37
3.6k
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
100
Transcript
テスト書きたいけど テスト書きたいけど 書けてないのは何でなんだぜ 書けてないのは何でなんだぜ 2024-07-19 PHP勉強会 神戸
自己紹介 堂薗 伸樹(どうぞの のぶき) @DPontaro 所属:スターフェスティバル株式会社 大阪在住 妻、男の子2人、犬 ゲーム開発 → Webアプリケーション 登壇経験あまりないので、緊張してます
今日話すこと テストって書いたほうがいいよね でも書けてないことが多々ある なんでだっけを掘り下げて書く意欲をあげていきたい
私とはじめてのテスト はい いいえ
BDDフレームワーク ソシャゲのwebview画面のテスト に導入されました 初めて触れたテスト behat
ユニットテストもしたことない メンテつらい メリットがわからない 結局書かなくなった 初めて触れたテスト behat テストに対しての第一印象はよくなかった
テストの目的、メリット はい いいえ
リファクタリング 振る舞いを変えずに、安全に変更できる 品質保証 バグの早期発見、修正 不具合の再現(回帰テスト) ドキュメンテーション テストコード自体が仕様の説明になる 設計の改善 テスタブルなコードを書くことで、結果的に良い設計になる etc...
なんで書かないの? メリットいっぱいじゃん?
なんで書けてないんだっけ? はい いいえ
(満足いくほど)書けてないのはなぜか 成功体験が足りていない 自動テストの環境が整っていない 時間がない
成功体験を積めていない 労力 < メリット を感じる場面が多くないのではないか 最初がbehatだったので余計に。 自動テストの環境が整っていない 仕組みによる強制がないので、書かずとも進行してしまう開発 そして仕込まれる不具合 時間がない 眼の前のスケジュールにアップアップで、実装と動作確認で手一杯
はい
じゃあどうしていこうね はい いいえ
時間がない 書かないと早くはならない 時間がかかるのは、道具が手に馴染んでいない アサーション モック やれることを知っていても細かい書き方覚えてなく、ググる、ジピる時間が出てきたりす る 書いて脳と手に刻み込む。
時間がない ユニットテストから慣れていこう AAAパターン テストダブル(スタブ、モック、etc...) 設計の原則も知っていこう(テストしやすいクラスを意識していく) S:単一責任の原則 O:オープン / クローズド 原則
L:リスコフの置換原則 I:インタフェース分離の原則 D:依存関係逆転の原則
はい
自動テストの環境がない つくろう!!! 新規に走り始めたり、まだ日が浅いプロジェクトはチャンス。 後になればなるほど構築はしんどくなる。今すぐやろう
自動テストの環境がない そうはいってもCIのワークフロー作ったことないです やったことないと心理的ハードル高いよね、わかる GitHub Actions とか GitLab CI とかでやれるよ だいたい似たような流れになるよ
ワークフローが発火する条件 コードのチェックアウト 環境セットアップ テスト用のenvファイル作成 依存ライブラリのインストール テスト実行 (必要に応じて)結果をどこか(slackとか)に通知
自動テストの環境がない claudeに聞いてみた。 ざっと大まかな流れはこれで作れるので、 あとは多少の試行錯誤で動かせるはず。 がんばれ。
自動テストはあるけど、メンテされてなくて壊れてる この場合、どうしたらいいかは私が聞きたい 一旦部分的に重要なやつだけ、テスト通すようにしていくとか・・・? テスト実行時に特定のテストや、ディレクトリだけ指定するのはできるので そうして徐々に時間をかけて改善していく レガシーコード改善ガイド、あたりを読むといい?(積読状態) たいてい密結合しまくったコードが大量でテストしづらい状態 テストのためにリファクタリングしたいが、テストがないので安全にリファクタリングで きないパターン そのあたりの取り組み方とかも書いてあったような気がする
成功体験 きっとちょっとずつ積まれてるはず。思い出して。 behatのことは一旦忘れて。 仕様の漏れに気づく テストパターンを考えているうちに、想定しきれてない箇所に気づくことができた。 境界値テストとかやってると、まれによく出てくる 本番で発生した不具合の再現をテストに書いておいた 後日、別の人の機能実装時にきちんとこけてくれて同様の不具合を未然に防げた。 細かい修正はサクサク回して手早く動作確認できる phpunitだと、--filter
とか --group でローカルでは特定のテストだけ指定してサクサク 回したりしてる やってるうちに、きれいなクラス設計も見えてくるよ
成功体験 書いたら褒める!! 他人も褒める、自分も褒める、何回でも褒める テストを書くあなたは偉い!!!
ということで宣誓 引き続きやっていって呼吸するようにテストかけるようになります ただ量産するでなく、費やした労力に見合った結果を引き出せるテスト を作成できるようになります。
ご清聴ありがとうございました もっとテスト書いていきます はい