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
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
680
php-fpmのプロセスをコントロールする
dznbk
0
16
Other Decks in Programming
See All in Programming
CSC307 Lecture 03
javiergs
PRO
1
470
[AI Engineering Summit Tokyo 2025] LLMは計画業務のゲームチェンジャーか? 最適化業務における活⽤の可能性と限界
terryu16
2
300
AtCoder Conference 2025
shindannin
0
930
Giselleで作るAI QAアシスタント 〜 Pull Requestレビューに継続的QAを
codenote
0
340
【卒業研究】会話ログ分析によるユーザーごとの関心に応じた話題提案手法
momok47
0
170
Deno Tunnel を使ってみた話
kamekyame
0
320
MDN Web Docs に日本語翻訳でコントリビュート
ohmori_yusuke
0
440
20251212 AI 時代的 Legacy Code 營救術 2025 WebConf
mouson
0
250
Combinatorial Interview Problems with Backtracking Solutions - From Imperative Procedural Programming to Declarative Functional Programming - Part 2
philipschwarz
PRO
0
140
AI 駆動開発ライフサイクル(AI-DLC):ソフトウェアエンジニアリングの再構築 / AI-DLC Introduction
kanamasa
11
5.3k
組み合わせ爆発にのまれない - 責務分割 x テスト
halhorn
1
180
AIの誤りが許されない業務システムにおいて“信頼されるAI” を目指す / building-trusted-ai-systems
yuya4
7
4.3k
Featured
See All Featured
Site-Speed That Sticks
csswizardry
13
1k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
330
The Language of Interfaces
destraynor
162
26k
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
170
Building a Scalable Design System with Sketch
lauravandoore
463
34k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.3k
Everyday Curiosity
cassininazir
0
120
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
0
1.8k
How GitHub (no longer) Works
holman
316
140k
A Soul's Torment
seathinner
4
2.1k
Making Projects Easy
brettharned
120
6.5k
Test your architecture with Archunit
thirion
1
2.1k
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 でローカルでは特定のテストだけ指定してサクサク 回したりしてる やってるうちに、きれいなクラス設計も見えてくるよ
成功体験 書いたら褒める!! 他人も褒める、自分も褒める、何回でも褒める テストを書くあなたは偉い!!!
ということで宣誓 引き続きやっていって呼吸するようにテストかけるようになります ただ量産するでなく、費やした労力に見合った結果を引き出せるテスト を作成できるようになります。
ご清聴ありがとうございました もっとテスト書いていきます はい