InfoQ

News

モックオブジェクトをいつ使うか?

作者 Mike Bria, 翻訳者 大田 緑 - (株)チェンジビジョン 投稿日 2008年6月19日 午前12時45分

コミュニティ
Agile
トピック
アジャイル技術,
ユニットテスト
タグ
TDD,
Mocks
「Ode To Code」の中で、K Scott Allen氏は、ユニットテストでモックオブジェクトを使うのは合理的なことだと勧めて(source)、モックオブジェクトのフレームワークを使うことについて(source)彼の考えを述べている。

Allen氏は、モックについてもっとも一般的な誤解しそうなことについて鋭い議論で始める。
ユニットテストで使うのが難しいリソースで相互関係をシミュレートする必要があるときだけモックオブジェクトが役に立つと誤解する人がいます。それは、例えば、SMTPサーバーで通信するオブジェクトのようなものです。これは本当ではありません。
そして、Colin Mackay氏が書いたモックの記事を参照する(source)。そこでは、モックが役に立つという共通のシナリオを挙げている。
  • 実オブジェクトは決定されていない振る舞いを持つ。
  • 実オブジェクトは設定するのが難しい。
  • 実オブジェクトはトリガーするのが難しい振る舞いを持つ。
  • 実オブジェクトは遅い。
  • 実オブジェクトはユーザインタフェースである。
  • 実オブジェクトはコールバックを使う。
  • 実オブジェクトはまだ存在しない。
Allen氏は、それから上記のリストでさえ少し近視眼的かもしれないとほのめかし、彼のメッセージの要点に迫る。そして、「test double(テスト代役)[モック]はテストでコードを分離したいときに役に立つ」とさらに一般化して主張する。簡単に言うと、Allenによれば、ビジネスコンポーネントのテストを他のコンポーネントすべてから独立させてモックを使う。テストでコンポーネントは次のことに依存する。「A」が「B」を使い、「Aユニットテスト」は「B」の状態にかかわらず、「A」が動かない場合のみ動かなくなるべきである。

 
この記事は、実際のテスト駆動開発のモックオブジェクト(source)の役割に結び付けて続いている。
「役割をモックせよ、オブジェクトをモックするな(PDF・英語)」の著者はモックが次のようなものだと言います。


「オブジェクトが果たす役割に基づきシステムでタイプを識別するための技術」であり、「特に今分かるのは、モックオブジェクトのもっとも重要な利点は、私たちがもともとインタフェースの発見と呼ぶものであるということです。」

Allen氏は、JMock(source)、EasyMock(source)、NUnit(source)などのモックオブジェクトのフレームワークを使うことについて短い議論で締めくくる。要約すると、モックオブジェクトのフレームワークを効果的に使うのは大変だが、そのフレームワーク自身はむしろ簡単であるというのが彼の主張である。

チェックする価値がある関連した議論がTDD Yahooグループに出たばかりである。こちらで見てみよう(source)

原文はこちらです:http://www.infoq.com/news/2008/06/mocks-q-of-when

ブックマーク
digg+,
reddit+,
del.icio.us+,
dzone+,
Hatena

No comments

返信

特集コンテンツ一覧

トップスポーツチームの監督に教わる秘訣

この論文では、氏が発見した原則を要約し、その原則をいかにしてソフトウェア開発に応用するかを説明します。

事例研究:Dutch Railwaysのプロジェクトにおける分散拠点でのスクラム・プロジェクト

この記事では、私達がどのようにして大規模(240人月、10万行強)でインドとオランダの開発者も参加したスクラム・プロジェクトを成功させたのかを示しています。

Agile2008チーム参加レポート - 帰国そして変化

Agileカンファレンスに「参加者としてだけでなく、発表者として参加しよう」を掲げたチームgoyattomは、サブミッションを提出し、7つのセッションが日本から選択されました。参加者はカンファレンスで各々の発表や、各セッションへの参加、諸外国のエンジニアとの出会い、ステージ上で DearXPを熱演などの様々な思い出を抱えて、無事日本に戻ってきました。

SilverlightとJavaのインターオペラビリティ

マイクロソフトのRobert Bellが、SilverlightとJavaを使用したインターオペラビリティのシナリオを紹介し、サンプルコードを例にとってアーキテクチャの手引きを提供します。

Agile2008 チーム参加レポート - カンファレンス参加編

Agileカンファレンスに「参加者としてだけでなく、発表者として参加しよう」を掲げたチームgoyattomは、サブミッションを提出し、7つのセッションが日本から選択されました。サブミッションが選択された人、そうでない人も含めて、個々の目的意識の確認、膨大なプログラムから聞きたいセッションの選択、旅行の準備、プレゼンテーションの準備の期間を終えて、無事当日を迎えました。

Agile2008 チーム参加レポート - 動機/準備編

筆者はアジャイルソフトウェア開発についての年に一度の国際会議であるAgile2008に初めて参加してきました。今年の日本からの参加者の数は14名にも及び、発表者は5名、受け持ったセッションは8つに及び、例年にない活躍を見せました。なぜ今年のAgile2008では、これほど多くの日本人が参加し発表に至ったのか? そのレポートをお届けします。

Javaトラブルシューティングメルマガ総集編 2008/08~09

エスエムジーでは、Java全般を対象にしたトラブルシューティングサービス「JaTS」を提供しています。この記事では、前回に引き続き、JaTSにて蓄積したトラブル事例とその解決ノウハウの一部をお送りしている「Javaトラブルシューティングメールマガジン」(JTSMM)の総集編として、過去2ヶ月のトラブル事例と追加情報をダイジェストとして提供いたします。

モデル駆動アプローチがうまく機能しない(しなくなる)8 つの理由

この記事では、モデル駆動アプローチがうまく機能しない、または機能しなくなることによって期待した結果が実現できなくなる 8 つの理由について書きたいと思います。