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
D-PONTARO
July 20, 2024
Programming
0
100
テスト書きたいけど 書けてないのは 何でなんだぜ
D-PONTARO
July 20, 2024
Tweet
Share
Other Decks in Programming
See All in Programming
SpringBoot3.4の構造化ログ #kanjava
irof
2
990
第3回 Snowflake 中部ユーザ会- dbt × Snowflake ハンズオン
hoto17296
4
370
『GO』アプリ バックエンドサーバのコスト削減
mot_techtalk
0
140
負債になりにくいCSSをデザイナとつくるには?
fsubal
9
2.4k
『テスト書いた方が開発が早いじゃん』を解き明かす #phpcon_nagoya
o0h
PRO
2
220
技術を根付かせる / How to make technology take root
kubode
1
250
Domain-Driven Transformation
hschwentner
2
1.9k
Software Architecture
hschwentner
6
2.1k
CDK開発におけるコーディング規約の運用
yamanashi_ren01
2
120
2024年のWebフロントエンドのふりかえりと2025年
sakito
2
250
データの整合性を保つ非同期処理アーキテクチャパターン / Async Architecture Patterns
mokuo
47
17k
How mixi2 Uses TiDB for SNS Scalability and Performance
kanmo
37
14k
Featured
See All Featured
Bash Introduction
62gerente
611
210k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.1k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
30
4.6k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
49k
Designing on Purpose - Digital PM Summit 2013
jponch
117
7.1k
Building a Modern Day E-commerce SEO Strategy
aleyda
38
7.1k
Rails Girls Zürich Keynote
gr2m
94
13k
Measuring & Analyzing Core Web Vitals
bluesmoon
6
240
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
280
13k
The Power of CSS Pseudo Elements
geoffreycrofte
75
5.5k
[RailsConf 2023] Rails as a piece of cake
palkan
53
5.2k
Statistics for Hackers
jakevdp
797
220k
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 でローカルでは特定のテストだけ指定してサクサク 回したりしてる やってるうちに、きれいなクラス設計も見えてくるよ
成功体験 書いたら褒める!! 他人も褒める、自分も褒める、何回でも褒める テストを書くあなたは偉い!!!
ということで宣誓 引き続きやっていって呼吸するようにテストかけるようになります ただ量産するでなく、費やした労力に見合った結果を引き出せるテスト を作成できるようになります。
ご清聴ありがとうございました もっとテスト書いていきます はい