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
私のTDD
Search
Fujimura Daisuke
November 09, 2011
Programming
840
4
Share
私のTDD
Fujimura Daisuke
November 09, 2011
More Decks by Fujimura Daisuke
See All by Fujimura Daisuke
現役スタートアップCTOが解説する、ソフトウェア開発という仕事の理論・実践・キャリア
fujimura
0
140
庭と負債
fujimura
4
2.6k
AIの時代で我々はどのようにコードを書くのか
fujimura
4
1.1k
SaaSを作るという仕事について
fujimura
13
6.5k
一文字エイリアスのすすめ
fujimura
0
520
現役CTOが語る!RubyKaigiの楽しみ方
fujimura
0
1.4k
いかにして文系新卒エンジニアが「大きな問い」を大事にするCTOになったのか
fujimura
2
810
Kaigi on Rails 2022 - 既存Railsアプリ攻略法 CTOが見ること・やること・考えること
fujimura
14
5.6k
SimpleDelegator活用のご提案
fujimura
0
1.8k
Other Decks in Programming
See All in Programming
GNU Makeの使い方 / How to use GNU Make
kaityo256
PRO
16
5.6k
AI-DLC Deep Dive
yuukiyo
9
5k
The Past, Present, and Future of Enterprise Java
ivargrimstad
0
290
煩雑なSkills管理をSoC(関心の分離)により解決する――関心を分離し、プロンプトを部品として育てるためのOSSを作った話 / Solving Complex Skills Management Through SoC (Separation of Concerns)
nrslib
4
1.1k
検索設計から 推論設計への重心移動と Recall-First Retrieval
po3rin
4
1.3k
「Linuxサーバー構築標準教科書」を読んでみた #ツナギメオフライン.7
akase244
0
1.4k
The Monolith Strikes Back: Why AI Agents ❤️ Rails Monoliths
serradura
0
370
書き換えて学ぶTemporal #fukts
pirosikick
1
290
ハーネスエンジニアリングにどう向き合うか 〜ルールファイルを超えて開発プロセスを設計する〜 / How to approach harness engineering
rkaga
24
16k
When benchmarks go bad - what I learned from measuring performance wrong
hollycummins
0
180
アクセシビリティ試験の"その後"を仕組み化する
yuuumiravy
1
180
Road to RubyKaigi: Play Hard(ware)
makicamel
1
500
Featured
See All Featured
How STYLIGHT went responsive
nonsquared
100
6.1k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
390
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Building AI with AI
inesmontani
PRO
1
940
We Are The Robots
honzajavorek
0
220
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
110
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
61
43k
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
160
Ruling the World: When Life Gets Gamed
codingconduct
0
220
GraphQLとの向き合い方2022年版
quramy
50
15k
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
10k
Transcript
私のTDD 藤村大介 / @ffu_
TDDとは "プログラムに必要な各機能について、最初にテストを書き(これをテスト ファーストと言う)、そのテストが動作する必要最低限な実装をとりあえず行っ た後、コードを洗練させる、という短い工程を繰り返すスタイル” http://ja.wikipedia.org/wiki/テスト駆動開発
実演してみます
レコードバイヤーを実装します • 最初に予算をもらう • レコードは予算があるだけ買える
None
だめ
なんでもいいのでまずはテストを書いて、
失敗させる(儀式)
それから、希望する挙動を示すコードをテストとして書く 1000円渡すと予算 1000円のバイヤーが できますように…
失敗する メソッドがないそ うです
Buyer#budget を実装(”がわ”だけ)
失敗する 1000が欲しかったのにnilが返りました(当たり前)
コンストラクタで予算を渡し、#budgetで返すようにする (ちょっと端折りました)
できました
というふうに 最小の粒度でテストを流して開発していきます。 普段は手動で流すのは面倒なので、ファイルの変更を監視して自 動でテストを流すツール(watchrとか)を使ってます。 結果を見るためにウインドウを切り替えるのも面倒なので、常にテ ストの結果が画面の片隅に出ているようにしています。
ノートPCの場合はこんな感じでターミナルを重ねている
時は流れ
現在レコード購入機能を実装しています。これから予算制限をつけると ころ。(今は無制限に買える)まずはテストを書きます 予算を超えてたらレコー ドが増えないようにして ください
もちろん まず失敗 させる
実装簡単だし、 いちいち失敗させるのはアホらしいと思いますよね? しかし、
条件分岐を実装する際は、まずすべての 分岐を通るテストを書きます 面倒かもしれませんが、どうせあとで全部手で動かすんですよね? だったら再現できるようにしたほうがお得です。 さらに、正常系(もしくはその時動かしたい分岐)のみ通るコードを書 き、他の実装に進んでしまい…アッ気がついたら異常系の想定が漏 れてた、みたいなケースも起こりにくくなります。なぜならテストを書く 際に全パスの処理を想定する必要があり、それを実装するようテス トが示してくれるから。 (本当にやってます)
実装に戻ります
分岐を入れました。
通りました これで安心の条件分岐が実現された。
これを少しずつ進めていきます ちなみにソフトウェアテストそのものの技法をしっかり身につけておく とテストは書きやすくなり、また堅牢なコードになると思います。 この本がおすすめ はじめて学ぶソフトウェアのテスト技法 リー・コープランド (著), 宗 雅彦 (翻訳)
最後に、私のTDD 私、ソフトウェア開発の技法の中で何が好きか、と言うと、断然TDD です。夢中とまでは言いませんが、今更離れるのはあまりに辛い ツールであります。 そんなTDDとは私にとって一体何なのだろうのか?の話。
私は面倒くさがり、しかも仕事が雑です 更に落ち着きがなく、極めて散漫な性格です。仕事に時間がかかる のも嫌いです。 だからこそのTDD。最初はウザかったけど、 • 手戻りがない(常に再帰テストされる) • ミスが少なくなる(事前に全分岐のテストケースを想定) • やるべきことが示される(まず失敗させて、それから実装)
• 必要ないことをやらないで済む(テストが通れば実装完了) と、気がついたらTDDは自分の弱点をそっとカバーしてくれるのでし た。
みなさんも騙されたと思ってやってみてください。 最初は面倒かもしれません。慣れは必要です。 ツールや環境を整備すると、かなり負担は減ります。 開発環境でCIを動かす感覚で常にテストを流しておくとかなり楽で す。 watchrあたりを活用するとよいです。 watchr: https://github.com/mynyml/watchr
終わり