もうすぐ完成! テスト駆動開発によるボウリングのスコア計算プログラム
2015年2月19日(木)
- [高梨]大丈夫です!
それでは前回同様にBowlingGameクラスへの組み込みを進めていきましょう。判定するのは現在のフレームですから、配列の最後尾の要素を対象にしてください。 - [古谷]はい、lastメソッドを使用すれば良いですよね?
あと、今回は前回と違い、既にBowlingGameクラスにspare?メソッドが定義されていますので、これは削除かコメントアウトする必要がありますよね? - [高梨]その通りです!
ただ、リファクタリング方針を精査するまで削除せずにコメントアウトでお願いします。さてどうですか?
組み込めましたか? - [古谷]これで大丈夫ですか?
- [高梨]大丈夫です!
では、このタイミングでリファクタリングしましょう。先程コメントアウトしたBowlingGameクラスのspare?メソッド内では、@shot_no変数と@last_pins変数が参照されていますよね?
これらは、このメソッドの中でしか使用されていませんので、@shot_no変数の値を指定しているproceed_next_shotメソッドとあわせて、ごそっと削除してください。そしてこのタイミングで、コメントアウトしてあったspare?メソッドも削除してください。 - [古谷]そうか、いきなり削除していたらリファクタリングができなくなるから、一端はコメントアウトするように指示したんですね!
- [高梨]そうです。ただ、リファクタリングが進んで、本当に不要になったら即削除します。いつまでも意味なくコメントアウトしたコードを残し続けても百害あって一利なしです。
- [古谷]はい!ではまずは@last_pins変数とコメントアウトしたspare?メソッドを削除しました。
- [高梨]大丈夫です!
では引き続き@shot_noとproceed_next_shotを削除してください。 - [古谷]これでどうでしょう?
- [高梨]大丈夫です、だいぶ慣れてきましたね!
では、ストライク判定もFrameのstrike?メソッドを適用してください。ここでは、BowlingGame のstrike?メソッドを削除してFrameのstrike?メソッドに置き換えるだけで大丈夫です。strike?メソッドも、もう削除しちゃってください。 - [古谷]はい、できました!
- [高梨]素晴らしい!
- [古谷]ありがとうございます!
それにしても……今まで一生懸命考えてきたメソッドや変数をザックザク削除するのは、切ないような爽快なような微妙な感覚です…… - [高梨]気持ちはわかりますが、シンプルなコードに勝るものはありません。DRY(Don’t Repeat Yourself)という言葉があります。これは、プログラム中に同じようなコードをいくつも存在させてはいけない、という考え方です。
- [古谷]DRYは聞いたことがあります。そうですね、TDDの際は特に意識しておかないいと……
コードの断捨離、続けます! - [高梨]コードの断捨離、良い言葉ですね!
それでは勢いをつけて、次に進んでいきましょう。次回はいよいよ最終回、ボーナス点の保持と記録した点数を返す責務をFrameに委譲し、リファクタリングを極めましょう! - [古谷]はい!よろしくお願いします!
連載バックナンバー
Think ITメルマガ会員登録受付中
Think ITでは、技術情報が詰まったメールマガジン「Think IT Weekly」の配信サービスを提供しています。メルマガ会員登録を済ませれば、メルマガだけでなく、さまざまな限定特典を入手できるようになります。