テスト駆動開発へ
ようこそ
2014.02.01 TDD BootCamp 旭川
Shuji Watanabe (@shuji_w6e)

#tddbc
1
自己紹介
渡辺 修司 / @shuji_w6e
札幌Javaコミュニティ
やさしいデスマーチ
JUnit実践入門
Java, Groovy, JavaScript, AWS, TDD
ロードバイク、スノーボード
最近のお仕事...
昨年8月に転職
株式会社クラスメソッド
札幌にて在宅勤務
AWS利用者向けシステムの開発
主にフロントエンドや自動化などを担当
Spring, Ember.js, d3-data
ブログ業務
TDDBCへ
ようこそ
本日のスケジュール
11:00∼12:15 TDD, ユニットテストに関する講演
12:15∼12:30 ペアプロとお題の説明
12:30∼13:30 ペア作成、昼食、自己紹介など
13:30∼15:00 演習(前半)
15:00∼15:30 レビュー①
15:30∼17:00 演習(前半)
17:00∼17:30 レビュー②
17:30∼17:50 振り返り

※休憩やお手洗いはご自由にお取りください
TDD Boot Camp(TDDBC) とは、テスト
駆動開発(Test Driven Development)につ
いて、座学だけでなく、実習形式で手を
動かして体得することを目的とするイベ
ントです。
http://devtesting.jp/tddbc/
旭川発上陸
TDDBCで体験して欲しいこと
テストファースト
ユニットテスト
リファクタリング
TDDのサイクル
ペアプログラミング
コードレビュー
グリーンバンド

acts_as_professional
テスト駆動開発
テスト駆動開発とは?
ソフトウェアの開発手法
テスト駆動開発の1サイクル
はじめにテストコードを書く
テストが成功する必要最低限のコードを書く
テスト成功を維持してリファクタリングする
上記サイクルを素早くテンポ良く繰り返す
TDDのサイクル
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる
3.コードを書く
TDD三原則 - Uncle Bob
失敗するユニットテストより先にプロダクショ
ンコードを書いてはならない
テストケースのコンパイルが通り、適切に失
敗するまでは次のテストケースを書いてはな
らない
すべてのテストケースが成功するまでは次の
プロダクションコードを書いてはならない
TDD 品質保証テスト
品質保証テストはソフトウェアを対象とし、
品質担当者が高い品質を担保するために実施
TDDは品質を担保するわけではない
結果的に品質は高まるが主目的ではない
開発者が安心して開発できるための開発手法
TDDは設計やプログラム自体を対象とする
汚いコードは動かない
密結合
多重ネスト
巨大なクラス
多すぎる引数
多すぎる責務
きれいな動くコードへの道
きれい

汚い

動かない

動く
1.設計する
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる

きれい

3.コードを書く

汚い

動かない

動く
2.テストを書く
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる

きれい

3.コードを書く

汚い

動かない

動く
3.コードを書く
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる

きれい

3.コードを書く

汚い

動かない

動く
4.テストを成功させる
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる

きれい

3.コードを書く

汚い

動かない

動く
5.リファクタリング
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる

きれい

3.コードを書く

汚い

動かない

動く
1.設計する
1.設計する
5.リファクタリング

Heuristics

2.テストを書く

4.テストを成功させる

きれい

3.コードを書く

汚い

動かない

動く
TDDのこころ
©t-wada
小さく
個別に
すばやく
ひとつずつ、一歩ずつ
小さなステップで
大きなものは小さく分割
確実に、堅実に
手戻りを小さく
ひとりずつ、仕留める
テストは個別撃破する
次のテストを作らない
すばやくまわす
小さく回す

1.設計する
5.リファクタリング

早く回す

Heuristics

すぐに対応
リズム重要

2.テストを書く

4.テストを成功させる
3.コードを書く
使う
作る
伝える
自分が最初のユーザー
使いにくいものは使いにくい
自分で評価する
納得できるか?
恥ずかしくないか?
解りやすいか?
道具にこだわる
最高のパフォーマンスを維持する
プロとしてのこだわり
少しでも使いやすく
日々、研究・工夫
未来の自分が読む
テストコードは保守される
読みにくいコードは悪
シンプルに
名前重要
型
どうして、
テスト駆動開発を
導入するのか?
スキル不足

仕様変更

経験不足
複雑な要件

不安
http://www.flickr.com/photos/yopse/3772030400/
安全を確保する

http://www.flickr.com/photos/32010000@N08/2987901256/
なぜ、TDDを実践するか?
ソフトウェアは思った以上に複雑
パーフェクトプログラマなんかいない
不安だからユニットテストを書く
セーフティネットとしてのユニットテスト
すばやく回し、すばやいフィードバック
TDDが目指すところ

安心できる健康な開発
変更に強い健康なコード
難しそう・・・
http://www.flickr.com/photos/k1netik/50298297/
TDDはスキル
最初から完璧に出来る人はいない
原則は原則、出来る所から少しずつ
困ったら「TDDのこころ」を見直す
息を吸うようにテストコードを書き、

息を吐くようにプロダクトコードを書こう
TDDをはじめよう
TDDをはじめるワケ
設計力が高くなる
コードに自信が持てる!
1人でもはじめられる
開発が楽しくなる!!
TDDBCではじめるワケ
TAがいるから安心
1人で悩む必要がない
解らない事はみんなで考える
他のチームのコードを見ることができる
TDDBCの心得
http://www.flickr.com/photos/terrydonaghe/1117999/
1.手を動かす

http://www.flickr.com/photos/esti/4638056301/
2.議論する
http://www.flickr.com/photos/86921622@N00/281632021/
3.楽しむ

http://www.flickr.com/photos/monmo/21100814/
4.現実と戦う
http://www.flickr.com/photos/panoptikon/403903803/
ユニットテストが不安
ユニットテスト入門
ユニットテストとは?
システムを構成する最小部品のテスト

クラスやメソッドが対象
期待された振る舞いをするかを検証する
テストプログラムを作り自動化する

テスティングフレームワーク JUnit pyunit
最も基本的なテストなので最初に習得すべき
テストのポイント
特定の条件下で検証する(Test Case)
本来はどうあるべきか?(Expected)
実際にどうなっているのか?(Actual)
4フェイズテスト
1. 事前準備 (Setup)

事前条件や必要なデータを作成する
2. 実行 (Exercise)

対象となるメソッドを1回だけ呼び出す
3. 検証(Verify)

期待値と実測値を比較する
4. 後処理(TearDown)
ユニットテストのポイント
テスト対象クラスに対しテストクラスを作成
テストケースで操作するのは1つのメソッド
事前条件と実行を混同しない
検証は細かく行い、問題を切り分ける
事前設計とテストファースト
外部的システムの振る舞い(システム境界)
プログラムのインターフェイス
内部的処理(private メソッド)
システム境界

IN

インターフェイス

内部的処理
内部的処理

OUT

内部的処理
内部的処理
リファクタリング
ユニットテストの最大の目的のひとつ
外部的振る舞いを壊さずに実装を変更
privateメソッドのテストをしない
デモ

テスト駆動開発へようこそ