阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 逻辑覆盖法是设计白盒测试用例的主要方法之一,它通过对程序逻辑结构的遍历实现程序的覆盖。针对以下由C语言编写的程序,按要求回答问题。 gz_open (const char*mode

admin2012-06-06  22

问题 阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
   逻辑覆盖法是设计白盒测试用例的主要方法之一,它通过对程序逻辑结构的遍历实现程序的覆盖。针对以下由C语言编写的程序,按要求回答问题。
   gz_open (const char*mode)
   {
   char*p=  (char*)mode;    //1
   char    fmode[4];
   char*m=fmode;
   char  smode= ’\0’;
   char level=’\0\’;
   int strategy=0;
   do {
   if  (*p==’r’)    //2
   smode - ’r’;    //3
   if  (*p>=’O’&&*p<=’9’)  {    //4,5
   level=*p-’0’;    //6
   }  else if  (*p==’f’)  {    //7
   strategy=1;    //8
   }else  {    //9
   *m++=*p;
   }
   *p++;    //10
   }while  (m!=fmode+sizeof (fmode));    //11
   }                                 //12
  假设函数gz_open的参数mode是由26个小写字母’a’-’z’、数字’0’-’9’以及空格组成的字符串,请使用基本路径测试法构造1个测试用例,使之覆盖所有基本路径。

选项

答案构造一个6个字符构成的字符串(设为x,y,z,u,v,w 6个字符),使得每个字符覆盖一条基本路径。其中,x=’r’,y=’f’,z∈[’0’-’9’],u<’0’,v>’9’并且v!=’f’,w任意,这6个字符可任意排列。例如,mode="rOf aa"。

解析 本问题考查白盒测试用例设计方法中的基本路径法。涉及到的知识点包括:根据控制流图和环路复杂度设计测试用例。注意环路复杂度只是测试用例数的上限。
   本题中程序的环路复杂度为6,因此测试用例上限为6,但本题程序比较特殊,只需要一个测试用例即可实现。例如,构造一个6个字符构成的字符串(设为x,y,z,u,v,w6个字符),使得每个字符覆盖一条基本路径即可。其中,X=’r’,y=’f’,z∈[’0’-’9’],u<’0’,v>’9’并且v!=’f’,w任意,这6个字符可任意排列。
转载请注明原文地址:https://kaotiyun.com/show/H7WZ777K
0

最新回复(0)