软件测试第二次作业

Posted Snorlax

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软件测试第二次作业相关的知识,希望对你有一定的参考价值。

知识点内容回顾:

主要介绍了三个概念之间的区别

首先说最根本问题

Fault,什么事falut呢,代码中存在的问题,也就是和运行环境啊什么的没关系,你的代码就是有问题的,换句话说,你的实现是有问题的,但是这个问题不一定会被触发也不一定会导致error,但是无论是否导致了error都是有fault的。

其次是Error,在代码执行的过程中,运行了上面的Faults,就会出现错误,(当然也有可能不出现错误),但是这个状态称之为error,可能会导致failure

 

接下来说Failure,这个就是最终出现了错误的行为,那么就是failures了。

 

一般来说是Fault->Error->Failure这样的感觉

一切的根源是代码中的faults,faults会产生Error最终有可能导致failures。。。

接下来说说本周的作业题

public int findLast (int[] x, int y) { 

        //Effects: If x==null throw               

        //               NullPointerException 

        // else return the index of the last element 

        // in x that equals y. 

        // If no such element exists, return -1     

        for (int i=x.length-1; i > 0; i--) 

        { 

                if (x[i] == y) 

                { 

                        return i; 

                } 

        } 

        return -1; 

}

 // test: x=[2, 3, 5]; y = 2 

// Expected = 0

      

1.Fault:for循环的控制条件i > 0这里应该是i>=0,否则将不会访问x[0];

2.一个不执行fault的样例

x = {} y = 3;

这样情况会直接访问无效内存导致程序挂掉

3.执行了fault但是没有返回错误的值

x={1,2,3} y = 2

期望是1,答案也是1

4.导致错误但不会失败的

x={1,2,3},y =0

期望答案是-1,实际答案是-1;

public static int lastZero (int[] x) {

        //Effects: if x==null throw 

        //           NullPointerException 

        // else return the index of the LAST 0 in x. 

        // Return -1 if 0 does not occur in x 

        for (int i = 0; i < x.length; i++) 

        {

                 if (x[i] == 0) 

                { 

                        return i;

                } 

        } 

        return -1; 

}

// test: x=[0, 1, 0] 

// Expected = 2

1.fault代码是找数组中最后一个0的位置,但是却实现的是查询第一个0的位置

2.不执行fault,因为从循环处就有fault(方向反了)所以不存在不执行fault的用例

3.执行fault但不Error的情况是数组只有一个元素,无论正反遍历都不会有区别(都是只遍历下标为0不存在正反)

比如x={4};

4.执行fault导致error但没有failure的,当x中只有一个或没有0的时候

x = {1,0,2,3}

答案为1期望答案也为1

 

以上是关于软件测试第二次作业的主要内容,如果未能解决你的问题,请参考以下文章

软件测试第二次作业

软件测试第二次作业

软件测试第二次作业

软件工程管理——第二次作业

软件测试第二次作业

软件工程第二次作业