Junit4测试基本应用(白盒测试)

Junit4测试基本应用(白盒测试)

一、实验目的

掌握Junit的基本操作,进行较简单的单元测试。

二、Junit4测试的使用

1. 创建java项目JUnitText

我使用的Eclipse,在左侧Package Explorer(包资源管理器)右键,新建Java Project,输入项目名,Finish即可。

2. 创建java类calTriArea

public class calTriArea {public boolean judge(double a,double b,double c){boolean flag = false;if(a + b > c && a + c > b && b + c > a){flag = true;}if(a <= 0 || b <= 0 || c <= 0){flag = false;}return flag;}public double cal(double a,double b,double c) {double area = -1.0;if(judge(a, b, c)){if(a == b && b == c){area = Math.sqrt(3) / 4 * a * a ;}else{double p = (a + b + c)/2;area = Math.sqrt( (p * ( p - a ) * ( p - b ) * ( p - c ) ) );}return area;}return area;}}

3. 给项目导入JUnit4.jar包

在项目名处点击右键,选择最下面—-Properties(特性)—>Java Build Path—>Libraries—>Add Libraries—>JUnit–>Next–>Finish

4. 编写JUnit4测试类

在要测试类处右键,选择new-Junit Text Case–Next–选择你需要测试的方法–Finish,然后就开始填充空白测试。

import static org.junit.Assert.*;import org.junit.Test;public class calTriAreaTest {private static calTriArea cal = new calTriArea();   @Testpublic void testJudge() {//不能构成三角形 正数assertEquals(false, cal.judge(2, 1, 3));}@Testpublic void testJudge1() {//可以构成三角形assertEquals(true, cal.judge(3, 4, 5));}@Testpublic void testJudge2() {//不能构成三角形 负数assertEquals(false, cal.judge(-3, -4, -5));}@Testpublic void testCal() {//等边三角形assertEquals(3.89711431,cal.cal(3, 3, 3),0.00001);}@Testpublic void testCal1() {//一般三角形assertEquals(6.0,cal.cal(3, 4, 5),0.00001);}@Testpublic void testCal2() {//不能构造三角形  正数assertEquals(-1.0,cal.cal(2, 1, 3),0.00001);//浮点数比较是以差值小于某个精度表示,比较两个浮点数,要加上第三个参数,表示精度}@Testpublic void testCal3() {//不能构造三角形 负数assertEquals(-1.0,cal.cal(-2, -1, -3),0.00001);}}

5. 测试结果

运行测试类,进行测试—

二、实验任务

1)设计和实现一个程序,求三角形面积。其中等边三角形用计算三角形面积通用公式计算,而任意三角形用海伦公式计算(S=√p(p-a)(p-b)(p-c) )其中,p=(a+b+c)/2)。

2)根据编写的代码使用Junit进行测试。

三、实验步骤

1、首先理解实验内容,根据实验要求,在IDE下编写计算三角形面积程序。

package junit_test;public class calTriArea {public boolean judge(double a,double b,double c){boolean flag = false;if(a + b > c && a + c > b && b + c > a){flag = true;}if(a <= 0 || b <= 0 || c <= 0){flag = false;}return flag;}public double cal(double a,double b,double c) {double area = -1.0;if(judge(a, b, c)){if(a == b && b == c){area = Math.sqrt(3) / 4 * a * a ;}else{double p = (a + b + c)/2;area = Math.sqrt( (p * ( p - a ) * ( p - b ) * ( p - c ) ) );}return area;}return area;}}
  1. 使用白盒测试技术中的逻辑覆盖设计测试用例,形成简单的测试用例文档。

测试用例ID

a

b

c

预期输出

T1

3

4

5

6.0

T2

1

2

3

您输入的三条边不能构成三角形

T3

3

3

3

3.9

T4

-3

4

5

您输入的三条边不能构成三角形

T5

3

2

2

2.0

运行结果截图:

  1. 使用黑盒测试技术中的等价类划分设计测试用例,形成简单的测试用例文档。

测试用例ID

a

b

c

预期输出

T1

-1

-1

-5

您输入的三条边不能构成三角形

T2

6

8

10

24.0

T3

10

10

10

43.3

T4

2

4

4

3.9

T5

0

4

5

您输入的三条边不能构成三角形

运行结果截图

  1. 使用Junit编写测试类。
package junit_test;import static org.junit.Assert.*;import org.junit.Test;public class calTriAreaTest {private static calTriArea cal = new calTriArea();   @Testpublic void testJudge() {//不能构成三角形 正数assertEquals(true, cal.judge(3, 4, 5));}@Testpublic void testJudge1() {//可以构成三角形assertEquals(false, cal.judge(1, 2, 3));}@Testpublic void testJudge2() {//不能构成三角形 负数assertEquals(true, cal.judge(3, 3, 3));}@Testpublic void testJudge3() {//不能构成三角形 负数assertEquals(false, cal.judge(-3, 4, 5));}@Testpublic void testJudge4() {//不能构成三角形 负数assertEquals(false, cal.judge(3, 2, 2));}@Testpublic void testCal() {//等边三角形assertEquals(6.0,cal.cal(3, 4, 5),0.00001);}@Testpublic void testCal1() {//一般三角形assertEquals(-1.0,cal.cal(1, 2, 3),0.00001);}@Testpublic void testCal2() {//不能构造三角形  正数assertEquals(3.9,cal.cal(3, 3, 3),0.00001);//浮点数比较是以差值小于某个精度表示,比较两个浮点数,要加上第三个参数,表示精度}@Testpublic void testCal3() {//不能构造三角形 负数assertEquals(-1.0,cal.cal(-3, 4, 5),0.00001);}@Testpublic void testCal4() {//不能构造三角形 负数assertEquals(2.0,cal.cal(3, 2, 2),0.00001);}}package junit_test;import static org.junit.Assert.*;import org.junit.Test;public class calTriAreaTest {private static calTriArea cal = new calTriArea();   @Testpublic void testJudge() {//不能构成三角形 正数assertEquals(true, cal.judge(6, 8, 10));}@Testpublic void testJudge1() {//可以构成三角形assertEquals(false, cal.judge(-1, -1, -5));}@Testpublic void testJudge2() {//不能构成三角形 负数assertEquals(true, cal.judge(10, 10, 10));}@Testpublic void testJudge3() {//不能构成三角形 负数assertEquals(false, cal.judge(0, 4, 5));}@Testpublic void testJudge4() {//不能构成三角形 负数assertEquals(true, cal.judge(2, 4, 4));}@Testpublic void testCal() {//等边三角形assertEquals(-1.0,cal.cal(-1, -1, -5),0.00001);}@Testpublic void testCal1() {//一般三角形assertEquals(24.0,cal.cal(6, 8, 10),0.00001);}@Testpublic void testCal2() {//不能构造三角形  正数assertEquals(43.3,cal.cal(10, 10, 10),0.00001);//浮点数比较是以差值小于某个精度表示,比较两个浮点数,要加上第三个参数,表示精度}@Testpublic void testCal3() {//不能构造三角形 负数assertEquals(3.9,cal.cal(2, 4, 4),0.00001);}@Testpublic void testCal4() {//不能构造三角形 负数assertEquals(-1.0,cal.cal(0, 4, 5),0.00001);}}
  1. 使用测试用例的数据驱动测试类执行,可以使用参数化测试和打包测试等方法进行自动化测试。

运行结果:(绿色√表示测试通过,蓝色√表示结果不精确,红色√表示测试通不过)

  1. 分析测试数据,根据测试结果进行程序的修改。

由Junit测试类运行结果可以看出,对于结果中蓝色√的部分应该修改运行结果,使其精度符合软件要求。

修改后运行结果如下:

7、在实验过程中进一步加强Junit测试件是应用和知识学习。

(1)、 JUnit 是一个开源的 Java 语言的单元测试框架

专门针对 Java 语言设计,使用广泛;

JUnit 是事实上的标准单元测试框架。

(2)、 JUnit 的特点

使用断言( Assertion )测试期望结果;﹣可以方便地组织和运行测试

可以方便地查看测试结果

常用 IDE (例如 IntelliJ ldea 、 eclipse )都集成了 JUnit

可以方便地集成到 Maven 。

四、JUnit 设计

TestCase :一个 TestCase 表示一个测试。

TestSuite :一个 TestSuite 包含一组 TestCase ,表示一组测试。

TestFixture :一个 TestFixture 表示一个测试环境。

TestResult :用于收集测试结果。

TestRunner :用于运行测试。

Testlistener :用于监听测试过程,手机测试数据;

Assert :用于断言测试结果是否正确。

(3)、Assert 断言常用方法:

断言相等: assertEquals (100, X );

断言数组相等: assertArrayEquals ((1,2,3, X );

浮点数断言相等:0 assertEquals (3.1416, X , 0.0001);

断言为 nul:assertNull ( X );

断言为 true / false:assertTrue ( x >0 ) / assertFalse ( x < 0 )

求三角形面积主函数:

package junit_test;import java.util.Scanner;public class junit_area {public static void main(String[] args) {// TODO Auto-generated method stubdouble d;double e;double f;System.out.println("请输入三角形的三条边长:");Scanner in=new Scanner(System.in);d=in.nextDouble();e=in.nextDouble();f=in.nextDouble();calTriArea cal=new calTriArea();if(cal.judge(d,e,f)) {System.out.printf("三角形面积是:%.8f\n",cal.cal(d,e,f));}else {System.out.println("您输入的三条边不能构成三角形!");}}}

简单软件缺陷报告:

测试模块:

对三角形求面积使用Junit测试方法进行测试

开 发 者:

测 试 员:

测试日期:

2024.6.17

软件缺陷列表

缺陷ID

缺陷详细信息

BUG1

所求结果精度不达标

BUG2

BUG3

BUG4

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/857252.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

若依 ruoyi 排序 顺序 倒序 的实现

1. table标签新增排序相关属性 // :default-sort"defaultSort" 指定默认排序 // sort-change"handleSortChange" 指定排序点击事件 :default-sort"defaultSort" sort-change"handleSortChange" 2. 列上新增排序相关配置 自定义查询语…

mac苹果窗口辅助工具:Magnet for mac 2.14.0中文免激活版

Magnet 是一款针对 MacOS 系统的窗口管理工具软件。它能够帮助用户更加高效地管理和组织桌面上的窗口&#xff0c;通过简单的快捷键操作&#xff0c;可以将窗口自动调整到指定的位置和大小&#xff0c;实现多窗口快速布局。Magnet 还支持多显示器环境下的窗口管理&#xff0c;可…

JAVA每日总结day6.21

ok了家人们&#xff0c;今天我们学习了面向对象中关键字的使用和抽象类&#xff0c;话不多说&#xff0c;我们一起看看吧&#xff0c;&#xff08;今天终于星期五了&#xff0c;芜湖&#xff01;&#xff01;&#xff01;&#xff09; 一&#xff0c;this和super关键字 1&…

kakfa发版丢消息事件分析

背景 其他部门同事反馈在项目发版/重启(kill -15)的那段时间&#xff0c;经常会出现导致 C 端业务出现问题&#xff0c;从而产生资损 一听资损&#xff0c;赶紧应答下来&#xff0c;了解了下具体情况&#xff0c;然后立马去排查了 问题分析 结合同事的描述以及对业务的了解&a…

深度神经网络一

文章目录 深度神经网络 (DNN)1. 概述2. 基本概念3. 网络结构 深度神经网络的层次结构详细讲解1. 输入层&#xff08;Input Layer&#xff09;2. 隐藏层&#xff08;Hidden Layers&#xff09;3. 输出层&#xff08;Output Layer&#xff09;整体流程深度神经网络的优点深度神经…

Redis-事务-基本操作-在执行阶段出错不会回滚

文章目录 1、Redis事务控制命令2、Redis事务错误处理3、Redis事务错误处理&#xff0c;在执行阶段出错不会回滚 1、Redis事务控制命令 127.0.0.1:6379> keys * (empty array) 127.0.0.1:6379> multi OK 127.0.0.1:6379(TX)> set a1 v1 QUEUED 127.0.0.1:6379(TX)>…

深度学习前10节

1.机器学习的流程 (1)数据获取 &#xff08;2&#xff09;特征工程 &#xff08;3&#xff09;建立模型 &#xff08;4&#xff09;评估与应用 2.特征工程的作用 &#xff08;1&#xff09;数据特征决定了模型的上限 &#xff08;2&#xff09;预处理和特征提取是最核心的 &…

【Android面试八股文】你能说一说自定义View与ViewGroup的区别

文章目录 Android UI 组件:View 和 ViewGroupViewGroup 的职责View 的职责自定义 View 和 ViewGroup 的区别1. 继承的类不同2. 主要功能不同3. 重写方法不同4. 使用场景不同5. 事件分发方面的区别6. UI 绘制方面的区别Android UI 组件:View 和 ViewGroup 在 Android 开发中,…

CTF-pwn-虚拟化-qemu前置知识

文章目录 参考地址相关交互相关配置相关调试待完善&#xff08;以后做题用到啥再加吧&#xff09; 参考 https://xz.aliyun.com/t/6562?time__1311n4%2bxnD0DRDBAiGkDgiDlhjmYh2xuCllx7whD&alichlgrefhttps://www.bing.com/#toc-3 地址相关 每个qemu虚拟机都是宿主机上…

JVM的类加载机制

Java中类的加载阶段 类加载 Java中的类加载机制是Java运行时环境的一部分&#xff0c;确保Java类可以被JVM&#xff08;Java虚拟机&#xff09;正确地加载和执行。类加载机制主要分为以下几个阶段&#xff1a; 加载&#xff08;Loading&#xff09;&#xff1a;这个阶段&#x…

AI助手,办公提效好工具!

随着人工智能AI技术的发展&#xff0c;AI工具已经成为我们提高工作效率的重要工具。无论是日常办公、学习还是生活娱乐&#xff0c;AI工具都能为我们提供支持和帮助。下面小编就来和大家分享几款AI助手&#xff0c;方便大家了解和使用AI工具。 1. Kimi智能助手 Kimi智能助手是…

H3C综合实验

实验拓扑 实验要求 1、按照图示配置IP地址 2、sw1和sw2之间的直连链路配置链路聚合 3、 公司内部业务网段为VLAN10和VLAN20; VLAN 10是市场部&#xff0c;vlan20是技术部&#xff0c;要求对VLAN进行命名以便识别&#xff1b;PC1属于vlan10&#xff0c;PC2属于vlan20&#xf…

神经网络模型的量化简介(工程版)

1.量化简介 模型量化&#xff08;Model Quantization&#xff09;是深度学习中一种优化技术&#xff0c;旨在减少模型的计算和存储需求&#xff0c;同时尽量保持模型的性能。具体来说&#xff0c;模型量化通过将模型的权重和激活值从高精度&#xff08;通常是32位浮点数&#…

数学建模整数规划学习笔记

与线性规划的本质区别在于决策变量是否取整。 &#xff08;1&#xff09;分支定界法 若不考虑整数限制先求出相应松弛问题的最优解&#xff1a; 若松弛问题&#xff08;线性规划&#xff09;无解&#xff0c;则ILP&#xff08;整数规划&#xff09;无解。 若求得的松弛问题最…

phar反序列化及绕过

目录 一、什么是phar phar://伪协议格式&#xff1a; 二、phar结构 1.stub phar&#xff1a;文件标识。 格式为 xxx; *2、manifest&#xff1a;压缩文件属性等信息&#xff0c;以序列化存 3、contents&#xff1a;压缩文件的内容。 4、signature&#xff1a;签名&#…

视频云存储平台LntonCVS国标视频平台功能和应用场景详细介绍

LntonCVS国标视频融合云平台基于先进的端-边-云一体化架构设计&#xff0c;以轻便的部署和灵活多样的功能为特点。该平台不仅支持多种通信协议如GB28181、RTSP、Onvif、海康SDK、Ehome、大华SDK、RTMP推流等&#xff0c;还能兼容各类设备&#xff0c;包括IPC、NVR和监控平台。在…

等保2.0中,如何确保云服务提供商的数据主权合规?

等保2.0&#xff08;网络安全等级保护2.0&#xff09;为了确保云服务提供商的数据主权合规&#xff0c;提出了若干关键措施和要求&#xff0c;主要包括但不限于以下几点&#xff1a; 1. 数据地理位置要求&#xff1a;明确规定云服务提供商必须保证所有基础设施位于中国境内&am…

海外云手机自动化管理,高效省力解决方案

不论是企业还是个人&#xff0c;对于海外社媒的营销都是需要自动化管理的&#xff0c;因为自动化管理不仅省时省力&#xff0c;而且还节约成本&#xff1b; 海外云手机的自动化管理意味着什么&#xff1f;那就是企业无需再投入大量的人力和时间去逐一操作和监控每一台设备。 通…

容器之滚动条窗体演示

代码; #include <gtk-2.0/gtk/gtk.h> #include <glib-2.0/glib.h> #include <gtk-2.0/gdk/gdkkeysyms.h> #include <stdio.h>int main(int argc, char *argv[]) {gtk_init(&argc, &argv);GtkWidget *window;window gtk_window_new(GTK_WINDO…

【经验分享】Ubuntu 24.04 安装搜狗输入法(亲测有效)

【经验分享】Ubuntu 24.04 安装搜狗输入法&#xff08;亲测有效&#xff09; 先用如下Ubuntu22.04的安装方法进行安装 Ubuntu 22.04安装搜狗输入法 发现存在闪屏问题&#xff0c;那解决闪屏问题不就好了。 解决方法如下&#xff1a; 解决方法1 Ubuntu 24.04安装搜狗输入法-解…