サマリ
ホワイトボックステストの4つの網羅基準について理解があいまいなので整理しました。
背景
IPAの情報処理試験の勉強をしているのですが、午前問題で出るホワイトボックステストの網羅基準がぼや~っとしたまま理解できていないので、
この機に整理することにしました。
お断り
個人的に調べ、理解した内容なので誤りが含まれている可能性があります。。
(その際はご指摘いただけると幸いです)
対象読者
- IPAの試験受験をしている方
- ホワイトボックステストをする方
ホワイトボックステストとは
Wiki先生によると以下です。
ホワイトボックステスト (英: white-box testing)は、アプリケーションの機能(ブラックボックス)ではなく、アプリケーションの内部構造をテストするソフトウェアテストの手法である。構造テストとも呼ばれる。開発したソフトウェアを中身が見える箱として扱い、内部論理を網羅的にテストする。プログラムが辿る経路をどれだけ実行したかを基準とする。
ソースコードレベルでのテストで、実装したプログラムが想定通りに動作するかという観点でのテストということですね。
Wiki先生によるとホワイトボックステスト自体の設計手法には下記があるとのことです。
(今回はそれぞれを深堀はしないこととします)
制御フローテスト
データフローテスト
ブランチテスト
ステートメントカバレッジ
決定範囲
変更された条件/決定範囲
プライムパステスト
パステスト
今回触れる網羅基準は、主に制御フローテスト(プログラムの処理フローが正しく実行されているか)の中で、
どこまで網羅的にチェックするかという観点で使用される基準で
主だったものとして4つあります。
4つの網羅基準について(本題)
というわけで前置きが長くなりましたが、それぞれについて整理したいと思います。
命令網羅(C0:ステートメント・カバレッジ)
すべての命令(処理)が実行されるようにテストケースを用意する考え方です。
分岐は意識せず、命令(処理)がすべて実行されることを意識するので
シンプルですね。
判定条件網羅(分岐網羅)(C1:ブランチ・カバレッジ)
今度は命令ではなく、分岐に関しての網羅性です。
各ひし形の分岐(ひし形から出ているルート)をすべて試せればOKです。
すべての分岐を通るので、分岐網羅が100%の時、命令網羅も100%になりますね。
条件網羅(C2:コンディション・カバレッジ)
ひし形の条件部分の網羅性ですね。
ひし形の各条件が少なくとも1回はtrue, falseとなるパターンを試します。(説明下手)
例えば、
画像の条件A or 条件Bが
x >=1 or y >= 0
だとすると、
(x, y) = (0, 0)なら条件A:false, 条件B:true
(x, y) = (1, 1)なら条件A:true, 条件B:false
という二つのテストケースを用意すれば、条件Aについてtrue, falseを1回は試せていますし、条件Bも同様です。
少なくとも1回なので、例えば条件Aと条件Bが両方falseとなるパターンや両方trueとなるパターンがなくても条件網羅の観点としてはOKです。
それゆえに、条件網羅が100%→判定条件網羅や命令網羅が100%とは限らないことに注意が必要です。
複合条件網羅(MCC:マルチコンディション・カバレッジ)
先ほどの条件網羅と考え方は近いですが、さらに厳しくパターンを試す考え方です。
先ほどは各条件式で少なくとも1回はtrue, false となるケースを実行できればよかったのに対し、
こちらは条件式の組み合わせすべてを試す網羅基準です。
(単体の条件だけでなく複合的な条件を網羅するということですね)
先ほどと同様に
条件A or 条件Bが
x >=1 or y >= 0
だとすると、
(x, y) = (0, 0)なら条件A:false, 条件B:true
(x, y) = (1, 1)なら条件A:true, 条件B:false
(x, y) = (1, 0)なら条件A:true, 条件B:true
(x, y) = (-1, -1)なら条件A:false, 条件B:false
と、true, falseの組み合わせすべてを試します。
全パターンなので、これを100%にすれば他の網羅基準はすべて100%になりますね。
ただ今回は条件式が2つだったので2×2の4パターンですが、
3つだと2×2×2の8パターン、と指数関数的に増加するのでかなりコストがかかることが予想できます。
(さらに判定条件(ひし形)の数が増えればさらに組み合わせ数は増えますね)
まとめ
- 命令網羅は命令(処理)に着目しすべての処理を実行
- 判定条件網羅(分岐網羅)は分岐に着目しすべての分岐を実行
- 条件網羅は判定の条件式に着目し、各条件で少なくとも1回はtrue,falseを実行
- 複合条件網羅も判定の条件式に着目するが、条件の組み合わせをすべて実行
試験における各カテゴリに対してこれぐらい丁寧に整理したいのが理想ですが、
時間の制約上そうもいかないのが現実…(泣
ある程度割り切りながらも、理解がボヤっとしている内容については今後もこうやって整理したいと思います。
参考
参考にさせていただいたサイトです。(ありがとうございます)