<html><head>
<meta http-equiv="Content-Type" content="text/html; charset=GB2312">
<title>白盒测试之基本路径测试法-UML软件工程组织-火龙果软件</title>
<link href="200804036.asp_files/style.css" rel="stylesheet" type="text/css">
</head><body>
<table align="center" border="0" cellpadding="0" cellspacing="0" width="760">
<tbody><tr>
<td> <div align="center">
<link href="200804036.asp_files/style.css" rel="stylesheet" type="text/css"> <table align="center" border="0" width="760">
<tbody><tr>
<td width="77"><object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,0,0" width="100" height="71">
<param name="movie" value="../../images/logo.swf">
<param name="quality" value="high">
<embed src="200804036.asp_files/logo.swf" quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" width="100" height="71"></object></td>
<td width="673"><font color="#008080" size="6" face="宋体"><strong> UML</strong></font><strong><font color="#008080"><font color="#008080" size="6" face="方正姚体">软件工程</font><font size="6" face="方正姚体">组织</font></font></strong> <table align="right" border="0" width="50%">
<tbody><tr>
<td class="content"><div align="center"><a href="http://www.uml.net.cn/" target="_blank" class="content_a">火龙果软件工程技术中心</a></div></td>
</tr>
</tbody></table></td>
</tr>
<tr>
<td colspan="2"><hr size="1" width="760" noshade="noshade"></td>
</tr>
<tr>
<td colspan="2"><div align="center">
<p class="content"> </p>
</div></td>
</tr>
</tbody></table>
</div></td>
</tr>
<tr>
<td><div class="title" align="center"> 白盒测试之基本路径测试法<br>
</div></td>
</tr>
<tr>
<td class="content" height="20"><div align="center"><strong>
<br>
</strong></div></td>
</tr>
<tr>
<td height="12">
<div class="formtitle" align="center">
<p>2008-04-03 作者:轩缘 来源:baidu.com</p>
</div></td>
</tr>
<tr>
<td class="content" height="16"> </td>
</tr>
<tr>
<td valign="top"><table class="content" align="center" border="0" cellpadding="1" cellspacing="1" width="90%">
<tbody><tr>
<td valign="top"><p> 白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、逻辑覆盖法、基本路径测试法、域测试、符号测试、Z路径覆盖、程序变异。</p>
<p> 其中运用最为广泛的是基本路径测试法。</p>
<p> 基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例的方法。</p>
<p> 设计出的测试用例要保证在测试中程序的每个可执行语句至少执行一次。</p>
<p> 在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例。包括以下4个步骤和一个工具方法:<br>
1. 程序的控制流图:描述程序控制流的一种图示方法。<br>
2. 程序圈复杂度:McCabe复杂性度量。从程序的环路复杂性可导出程序基本路径集合中的独立路径条数,这是确定程序中每个可执行语句至少执行一次所必须的测试用例数目的上界。<br>
3. 导出测试用例:根据圈复杂度和程序结构设计用例数据输入和预期结果。<br>
4. 准备测试用例:确保基本路径集中的每一条路径的执行。</p>
<p> 工具方法:</p>
<p> 图形矩阵:是在基本路径测试中起辅助作用的软件工具,利用它可以实现自动地确定一个基本路径集。</p>
<p> 程序的控制流图:描述程序控制流的一种图示方法。</p>
<p> 圆圈称为控制流图的一个结点,表示一个或多个无分支的语句或源程序语句</p>
<p><img src="200804036.asp_files/2008349891.jpg" width="480" height="186"></p>
<p>流图只有二种图形符号:<br>
图中的每一个圆称为流图的结点,代表一条或多条语句。<br>
流图中的箭头称为边或连接,代表控制流<br>
任何过程设计都要被翻译成控制流图。</p>
<p><strong>如何根据程序流程图画出控制流程图?</strong></p>
<p> 在将程序流程图简化成控制流图时,应注意:</p>
<ul>
<li>在选择或多分支结构中,分支的汇聚处应有一个汇聚结点。</li>
<li> 边和结点圈定的区域叫做区域,当对区域计数时,图形外的区域也应记为一个区域。</li>
</ul>
<p> 如下页图所示</p>
<p><img src="200804036.asp_files/2008349117.jpg" width="480" height="309"></p>
<p>如果判断中的条件表达式是由一个或多个逻辑运算符 (OR, AND, NAND, NOR) 连接的复合条件表达式,则需要改为一系列只有单条件的嵌套的判断。<br>
例如:<br>
1 if a or b<br>
2 x<br>
3 else<br>
4 y</p>
<p> 对应的逻辑为:</p>
<p><img src="200804036.asp_files/2008348349.jpg" width="312" height="200"></p>
<p>独立路径:至少沿一条新的边移动的路径</p>
<p><img src="200804036.asp_files/2008341748.jpg" width="480" height="282"></p>
<p><strong>基本路径测试法的步骤:</strong></p>
<p>第一步:画出控制流图</p>
<p>
流程图用来描述程序控制结构。可将流程图映射到一个相应的流图(假设流程图的菱形决定框中不包含复合条件)。在流图中,每一个圆,称为流图的结点,代表一
个或多个语句。一个处理方框序列和一个菱形决测框可被映射为一个结点,流图中的箭头,称为边或连接,代表控制流,类似于流程图中的箭头。一条边必须终止于
一个结点,即使该结点并不代表任何语句(例如:if-else-then结构)。由边和结点限定的范围称为区域。计算区域时应包括图外部的范围。</p>
<p><img src="200804036.asp_files/2008347909.jpg" width="480" height="317"></p>
<p>画出其程序流程图和对应的控制流图如下</p>
<p><img src="200804036.asp_files/2008342785.jpg" width="480" height="316"></p>
<p>第二步:计算圈复杂度</p>
<p> 圈复杂度是一种为程序逻辑复杂性提供定量测度的软件度量,将该度量用于计算程序的基本的独立路径数目,为确保所有语句至少执行一次的测试数量的上界。独立路径必须包含一条在定义之前不曾用到的边。</p>
<p> 有以下三种方法计算圈复杂度:<br>
流图中区域的数量对应于环型的复杂性;<br>
给定流图G的圈复杂度V(G),定义为V(G)=E-N+2,E是流图中边的数量,N是流图中结点的数量;<br>
给定流图G的圈复杂度V(G),定义为V(G)=P+1,P是流图G中判定结点的数量。</p>
<p> 第三步:导出测试用例 根据上面的计算方法,可得出四个独立的路径。(一条独立路径是指,和其他的独立路径相比,至少引入一个新处理语句或一个新判断的程序通路。V(G)值正好等于该程序的独立路径的条数。)</p>
<ul>
<li> 路径1:4-14</li>
<li> 路径2:4-6-7-14</li>
<li> 路径3:4-6-8-10-13-4-14</li>
<li> 路径4:4-6-8-11-13-4-14</li>
</ul>
<p> 根据上面的独立路径,去设计输入数据,使程序分别执行到上面四条路径。</p>
<p> 第四步:准备测试用例</p>
<p> 为了确保基本路径集中的每一条路径的执行,根据判断结点给出的条件,选择适当的数据以保证某一条路径可以被测试到,满足上面例子基本路径集的测试用例是:</p>
<p><img src="200804036.asp_files/2008341489.jpg" width="480" height="318"></p>
<p><strong>举例说明:</strong>流程图描述了最多输入50个值(以–1作为输入结束标志),计算其中有效的学生分数的个数、总分数和平均值。</p>
<p><img src="200804036.asp_files/2008341646.jpg" width="394" height="360"></p>
<p>步骤1:导出过程的流图。</p>
<p><img src="200804036.asp_files/2008348663.jpg" width="286" height="360"></p>
<p>步骤2:确定环形复杂性度量V(G):<br>
<br>
1)V(G)= 6 (个区域)<br>
2)V(G)=E–N+2=16–12+2=6<br>
其中E为流图中的边数,N为结点数;<br>
3)V(G)=P+1=5+1=6<br>
其中P为谓词结点的个数。在流图中,结点2、3、5、6、9是谓词结点。</p>
<p> 步骤3:确定基本路径集合(即独�