阅读下列C程序,回答下列问题。
[C程序] int GetMaxDay( int year, intmonth ) { int maxday = 0; //1 if ( month >= 1 && month <= 12 ) { //2,3 if ( month == 2 ) { //4 if ( year % 4 == 0 ) { //5 if ( year % 100 == 0 ) { //6 if ( year % 400 == 0 ) } //7 maxday = 29; //8 else //9 maxday = 28; } else //10 maxday = 29; } else //11 maxday = 28; } else{ //12 if(month==4||month==6||month==9||month==11) //13, 14, 15, 16 maxday = 30; //17 else //18 maxday = 31; } } return maxday; //19 }
3、请给出问题2中控制流图线性无关路径。
问题1:答案:基本路径测试法是在程序控制流图基础上,通过分析控制构造环路复杂性,导出基本可执行路径集合,从而设计测试用例方法。设计出测试用例要保证在测试中程序每个可执行语句至少执行一次。
问题2:答案:(1)控制流图如下图所示:

(2)V(G)=4+1=5
问题3:答案:(1) 1-2-3-8-10(2) 1-2-4-5-6-8-10(3) 1-2-3-4-5-6-8-10(4) 1-2-4-5-7-8-10(5) 1-2-3-8-9-10
【解析】
问题1:本小题考查基本路径法概念。
问题2:本题考查白盒测试方法中基本路径法。涉及到知识点包括:根据代码绘制控制流图、计算环路复杂度。控制流图是描述程序控制流一种图示方法。其基本符号有圆圈和箭线:圆圈为控制流图中一个结点,表示一个或多个无分支语句;带箭头线段称为边或连接,表示控制流。基本结构如下所示:

其中要特别注意是,如果判断中条件表达式是复合条件,即条件表达式是由一个或多个逻辑运算符连接逻辑表达式,则需要改变复合条件判断为一系列之单个条件嵌套判断。环路复杂度用来衡量一个程序模块所包含判定结构复杂程度。环路复杂度等于右图中判定节点个数加1。图中判定节点个数为4,所以V(G)=4+1=5。控制流程图环路复杂性 V(G)一共有以下三种方法,但是最后一种最好用,不易出错。(1)控制流程图中区域个数。(2)边数-结点数+2。(3)判定数+1。
问题3:本小题考查白盒测试用例设计方法之基本路径法。涉及到根据控制流图和环路复杂度给出线性无关路径。线性无关路径:指包含一组以前没有处理语句或条件路径。从控制流图上来看,一条线性无关路径是至少包含一条在其他线性无关路径中从未有过边路径。程序环路复杂度等于线性无关路径条数,所以本题中有5条线性无关路径。这5条路径组成了问题2中控制流图一个基本路径集。只要设计出测试用例能确保这些基本路径执行,就可以使程序中每个可执行语句至少执行一次,每个条件取真和取假分支也能得到测试。需要注意是,基本路径集不是唯一,对于给定控制流图,可以得到不同基本路径集。









