白盒测试:覆盖测试及测试用例设计

一、实验目的

1、掌握白盒测试的概念。

2、掌握逻辑覆盖法。

二、实验任务

      
一元二次方程式 ax2+bx+c=0的求根程序有以下功能:
1)输入A、B、C三个系数;
2)根据根的性质的:两个相等或不相等的实根,或无实根,输出相应的结果。
提示: 时,方程ax2+bx+c=0的解

【实验要求】
1) 绘制程序流图
2) 根据流程图得出白盒测试法(语句覆盖、判定覆盖、条件覆盖、条件组合覆盖)测试用例表
3) 用c或java实现功能
4)利用设计好的程序和测试用例,在相应的编程环境中进行测试,给出测试的结果(结果以截图方式表示即可)。

实验步骤:

1、画出程序流程图

判定1:a=0;

判定2:d>=0;

判定3:d=0;

2、根据逻辑覆盖法的六种覆盖标准设计测试用例,得到6张测试用例表

1、语句覆盖:分别需要执行1、3、4、6、8和1、3、4、7、8和1、3、5、8和1、2、8;

测试编号

a、b、c

判定1

判定2

判定3

预期输出

T1

a=0

不是一元二次方程

T2

2、3、2

方程无解

T3

2、5、3

-1.0和-1.5

T4

1、2、1

2、判定覆盖:分别需要执行1、3、4、6、8和1、3、4、7、8和1、3、5、8和1、2、8;

测试编号

a、b、c

判定1

判定2

判定3

预期输出

T1

a=0

不是一元二次方程

T2

2、3、2

方程无解

T3

2、5、3

-1.0和-1.5

T4

1、2、1

3、条件覆盖:分别需要执行1、3、4、6、8和1、3、4、7、8和1、3、5、8和1、2、8;

测试编号

a、b、c

判定1

判定2

判定3

预期输出

T1

a=0

不是一元二次方程

T2

2、3、2

方程无解

T3

2、5、3

-1.0和-1.5

T4

1、2、1

4、条件/判定覆盖:分别需要执行1、3、4、6、8和1、3、4、7、8和1、3、5、8和1、2、8;

测试编号

a、b、c

判定1

判定2

判定3

预期输出

T1

a=0

不是一元二次方程

T2

2、3、2

方程无解

T3

2、5、3

-1.0和-1.5

T4

1、2、1

5、条件组合覆盖:分别需要执行1、3、4、6、8和1、3、4、7、8和1、3、5、8和1、2、8;

测试编号

a、b、c

判定1

判定2

判定3

预期输出

T1

a=0

不是一元二次方程

T2

2、3、2

方程无解

T3

2、5、3

-1.0和-1.5

T4

1、2、1

6、修正条件判定覆盖:分别需要执行1、3、4、6、8和1、3、4、7、8和1、3、5、8和1、2、8;

测试编号

a、b、c

判定1

判定2

判定3

预期输出

T1

a=0

不是一元二次方程

T2

2、3、2

方程无解

T3

2、5、3

-1.0和-1.5

T4

1、2、1

6个判定覆盖的测试用例都相同,因为已经包含所有语句了

3、执行测试,填写软件缺陷报告。

测试用例结果截图

三、软件缺陷报告

测试模块:

工资计算程序

开 发 者:

XXX

测 试 员:

XXX

测试日期:

2024.5.8

软件缺陷列表

缺陷ID

缺陷详细信息

BUG1

BUG2

BUG3

BUG4

四、代码:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        while (true) {
            double a;
            System.out.println("输入a的值:");
            Scanner input = new Scanner(System.in);
            a = input.nextDouble();
            if (a == 0) {
                System.out.println("输入的不是一元二次次方程");
                System.exit(1);
            }
            System.out.println("输入b的值:");
            Scanner input1 = new Scanner(System.in);
            double b = input1.nextDouble();
            System.out.println("输入c的值:");
            Scanner input2 = new Scanner(System.in);
            double c = input2.nextDouble();
            double d = b * b - 4 * a * c;        //根据b^2-4ac判断方程可解性
            if (d < 0)
                System.out.println("方程无解");
            else if (d == 0)
                System.out.println("方程有一个解:" + -b / (2 * a));
            else
                System.out.println("方程有两个解:" + (-b + Math.sqrt(d)) / (2 * a) + "和" + (-b - Math.sqrt(d)) / (2 * a));//Math.sqrt()用来开平方
        }
    }

}

记录学习、记录生活,最后,我们终将会成为自己想成为的人✌✌✌

相关推荐

  1. 软件测试

    2024-05-10 03:30:05       59 阅读
  2. 设计测试

    2024-05-10 03:30:05       50 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-10 03:30:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-10 03:30:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-10 03:30:05       82 阅读
  4. Python语言-面向对象

    2024-05-10 03:30:05       91 阅读

热门阅读

  1. 第IV章-Ⅱ Vue3中的插槽使用

    2024-05-10 03:30:05       38 阅读
  2. 面试题:简述Go的垃圾回收机制

    2024-05-10 03:30:05       28 阅读
  3. QPicture,QPixmap和QImage的区别是什么

    2024-05-10 03:30:05       33 阅读
  4. map容器

    2024-05-10 03:30:05       34 阅读
  5. C#面试题: 寻找中间值

    2024-05-10 03:30:05       31 阅读
  6. Ps基础学习笔记

    2024-05-10 03:30:05       34 阅读
  7. reqwest - Rust HTTP Client

    2024-05-10 03:30:05       33 阅读