一、JUnit4 jar包下载

链接:https://pan.baidu.com/s/1AdeVGGikcY5dfL151ZnWHA
提取码:h1am

下载完成后,解压一下即可。

二、导入JUnit4 jar包

1.打开eclipse,右击你要进行单元测试的类所在的java项目,选择“Properties”选项

2.在弹出的对话框中选择“Java Build Path”----->"Add Library" 选项,进行构建JUnit4路径

3.在弹出的“Add Library”对话框中选择“JUnit”选项,单击“Next”按钮,在下拉列表中选择“JUnit4”,点击“Finish”,完成添加

4.添加完成后,单击“Apply”,应用变更,单击“OK”按钮,JUnit4构建成功,即可以使用JUnit4框架进行单元测试。

三、用JUnit4对一个算法题编写测试用例,进行测试。

1.首先来看这个算法题:

这个算法题有几个条件:

(1)要从起始点走到终点结束

(2)这个线段上的所有的点都要走一遍,但是每个点只能经过一次,

(3)在任何位置都可以用0次或多次技能跳到第一个点和第N个点(最后一个点)以达到以上两个条件

(4)三个值的范围是[1,10000] 且1<=S,T<=N

(5)用任何走法都不能达到目的则输出-1

(6)输入的参数是0或负数的时候,输出-1

(7)输入的终点T大于总点数S的时候,输出-1

(8)当N=S=T>1的时候,想要到达终点,终点所在的这个点始终要经过两遍,所以永远无法满足条件,则输出-1

(9)当N=S=T=1的时候,不用走,直接到终点,需要发动0次技能

(10)当S=1,T=N的时候,从第一个点走到最后一个点即可,也不用发动技能,所以是0次

(11)当S=1,T<N的时候,需要发动一次一次技能

(12)当终点在起始点的右侧相邻点(即T-S=1)的时候,需要发动一次技能

(13)当起始点大于1(S>1),终点小于N(T<N)的时候,也是只需发动一次技能

  图同上,但两个判定条件不一样,一个是起始点和终点相邻,一个是起始点和终点在第一个点和最后一个点中间

(14)当起始点大于1(S>1),终点为N(T=N)的时候,需要发动两次技能才能到达终点

根据以上分析,编写Java代码如下:

import java.util.Scanner;
public class Main66 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String nn = sc.next();
String ss = sc.next();
String tt = sc.next();
new Main66().count(nn,ss,tt);
}
private static int count = -1;
public int count(String nn,String ss,String tt){
//判断输入的是否是非数字
boolean nIsNum = nn.matches("^(\\d{1,4}|10000)$");
boolean sIsNum = ss.matches("^(\\d{1,4}|10000)$");
boolean tIsNum = tt.matches("^(\\d{1,4}|10000)$"); if(nIsNum && sIsNum && tIsNum){ int n = Integer.parseInt(nn);
int s = Integer.parseInt(ss);
int t = Integer.parseInt(tt); /*
*
* n<1 || s<1 || t<1 :判断负值和0值
* s==t && n!=s: 判断起始点和终点重合,并且总点数N>1(即永远无法到达终点)
* s>n || t>n: 判断起始点和终点对总点数n的越界
* s>t: 起始点是否大于终点
* */
if(n<1 || s<1 || t<1 || (s==t && n!=1) || s>n || t>n || s>t){
count = -1;
}else{
if(s==t && n==s && n==1){
count = 0;
}else if(s==1 && t==n){
count = 0;
}else if(s==1 && t<n){
count = 1;
}else if(t-n==1){
count = 1;
}else if(s>1 && t<n ){
count = 1;
}else if(s>1 && t==n){
count = 2;
}
}
}
System.out.println(count);
return count;
}
}

2.创建测试类,编写测试用例并执行

(1)右击“Main66”这个类,选择“New”---->"JUnit Text Case"

(2)在打开的“New JUnit Test Case”对话框中,项目路径,包名,要测试的类都是默认填好且正确的,检查无误,测试类的类名可以按照默认的“Main66Test”,也可以自己进行设置,

设置完成后,单击“Finish”按钮

(3)"Main66"的测试类就创建成功了

(4)根据上述编写算法题时列出的条件,一次性进行多组数据,每组数据多个参数的测试,以下是我写的对于这个算法题的测试用例

import static org.junit.Assert.*;
import java.util.Arrays;
import java.util.Collection;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters; //1、更改默认的测试运行器为@RunWith(Parameterized.class)
@RunWith(Parameterized.class)
public class Main66Test {
//2、声明变量定义预期值和初始值
int expected = 0;//预期值
String input1 = "";//输入值1
String input2 = "";//输入值2
String input3 = "";//输入值3 //3、声明一个返回值为Collection的公共静态方法,并使用@Parameters进行修改
@Parameters
public static Collection<Object[]> t(){
return Arrays.asList(new Object[][]{
//汉字测试
{-1,"输入","2","2"},
{-1,"2","阿尔戈","2"},
{-1,"2","2","热"}, //字母测试
{-1,"a","2","2"},
{-1,"2","a","2"},
{-1,"2","2","w"}, //字符测试
{-1,"@","2","2"},
{-1,"2",".","2"},
{-1,"2","2","'"}, //边界值测试
{-1,"10001","2","2"},
{-1,"2","10001","2"},
{-1,"2","2","10001"},
{-1,"10000","2","2"},
{-1,"2","10000","2"},
{-1,"2","2","10000"},
{-1,"9999","2","2"},
{-1,"2","9999","2"},
{-1,"2","2","9999"}, //大数测试
{-1,"2222222222222222222222","2","2"},
{-1,"2","22222222222222222222222222","2"},
{-1,"2","2","222222222222222222222222222222222"}, //空格测试
{-1," ","2","2"},
{-1,"2"," ","2"},
{-1,"2","2"," "}, //tab测试
{-1," ","2","2"},
{-1,"2"," ","2"},
{-1,"2","2"," "}, //负值测试
{-1,"-1","2","2"},
{-1,"2","-1","2"},
{-1,"2","2","-1"}, //0值测试
{-1,"0","2","2"},
{-1,"2","0","2"},
{-1,"2","2","0"}, //起点和终点重合,但总点数不为1
{-1,"6","6","6"},
{-1,"6","1","1"}, //越界测试
{-1,"1","2","1"},
{-1,"1","1","2"},
{-1,"1","2","2"}, {-1,"6","6","2"},
{-1,"6","3","2"}, //判定覆盖和条件覆盖
{2,"6","2","6"},
{0,"6","1","6"},
{1,"6","1","5"},
{0,"1","1","1"},
{1,"6","2","3"},
{1,"6","2","4"},
{1,"6","1","2"},
});
} //4、为测试类声明一个带有参数的公共构造方法,并在其中为变量赋值
public Main66Test(int expected,String input1,String input2,String input3){
this.expected = expected;
this.input1 = input1;
this.input2 = input2;
this.input3 = input3;
} //5.执行测试方法
@Test
public void testCount() {
assertEquals(expected,new Main66().count(input1,input2,input3));
}
}

(5)右键单击“Main66Test”,执行测试用例

(6)结果及主要参数的含义如下

测试完成。

ps:一个初学者的总结和分享,如果有描述不当的地方,还请各位大佬指正,感谢。

JUint4的下载、配置及对一个算法编写单元测试用例(测试多组数据每组多个参数)的更多相关文章

  1. Web —— java web 项目 Tomcat 的配置 与 第一个web 项目创建

    目录: 0.前言 1.Tomcat的配置 2.第一个Web 项目 0.前言 刚刚开始接触web开发,了解的也不多,在这里记录一下我的第一个web项目启动的过程.网上教程很多,使用的java IDE 好 ...

  2. 【嵌入式开发】 Linux Kernel 下载 配置 编译 安装 及 驱动简介

    作者 : 韩曙亮 转载请出名出处 : http://blog.csdn.net/shulianghan/article/details/38636827 一. Linux 内核简介 1. 内核功能简介 ...

  3. SecureCRT 下载,安装,绝佳配色,实用配置,上传下载配置合集

    SecureCRT 下载,安装,绝佳配色,实用配置,上传下载配置合集 chocoball 发布于 2年前,共有 3 条评论 SecureCRT 是一款支持 SSH2.SSH1.Telnet.Telne ...

  4. selenium的使用与chromedriver的下载配置

    Selenium是一个web自动化测试工具,最初是为网站自动化测试而开发的,Selenium可以直接运行在浏览器上,它支持所有主流的浏览器,可以接受指令,让浏览器自动加载页面,获得需要的数据,甚至页面 ...

  5. 抓包工具fiddler下载配置(一):下载/安装&信任证书

    简介 Fiddler一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(指cookie,html,js,css等文件 ...

  6. Node.js npm基础安装配置&创建第一个VUE项目

    使用之前,我们先来明白这几个东西是用来干什么的. node.js: 一种javascript的运行环境,能够使得javascript脱离浏览器运行.Node.js的出现,使得前后端使用同一种语言,统一 ...

  7. matlab使用libsvm入门教程——使用matlab安装配置libsvm以及一个svm分类实例

    前言 此教程专注于刚入门的小白, 且博客拥有时效性, 发布于2019年3月份, 可能后面的读者会发现一些问题, 欢迎底下评论出现的问题,我将尽可能更新解决方案. 我开始也在如何安装libsvm上出现了 ...

  8. 沁恒CH32F103C8T6(三): PlatformIO DAPLink和WCHLink下载配置

    目录 沁恒CH32F103C8T6(一): Keil5环境配置,示例运行和烧录 沁恒CH32F103C8T6(二): Linux PlatformIO环境配置, 示例运行和烧录 沁恒CH32F103C ...

  9. 介绍对称加密的另一个算法——PBE

    除了DES,我们还知道有DESede(TripleDES,就是3DES).AES.Blowfish.RC2.RC4(ARCFOUR)等多种对称加密方式,其实现方式大同小异,这里介绍对称加密的另一个算法 ...

随机推荐

  1. spring 5.x 系列第5篇 —— 整合 mybatis + druid 连接池 (xml配置方式)

    源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 项目目录结构 1.创建maven工程,除了Spring基本依赖外,还需要导 ...

  2. js获取radio选中索引值

    <form name="form1" onsubmit="return foo()"> <input type="radio&quo ...

  3. 【MYSQL】mysql大数据量分页性能优化

    转载地址: http://www.cnblogs.com/lpfuture/p/5772055.html https://www.cnblogs.com/shiwenhu/p/5757250.html ...

  4. c#基础四

    写入一个XML文件 using System; using System.Collections.Generic; using System.Linq; using System.Text; usin ...

  5. JavaScript 词法作用域不完全指北

    在 JavaScript 作用域不完全指北 中,我们介绍了作用域的概念以及 JavaScript 引擎.编译器和作用域的关系.作用域有两种主要的工作模型:词法作用域和动态作用域.其中最为普遍的也是大多 ...

  6. 2018.8.17 2018暑假集训 关于dp的一些感想(以目前的知识水平)

    学了这么长时间的dp似乎还是不怎么样 谨以此篇文字记录一年以来与dp斗智斗勇的各种经历 关于dp(也就是动态规划)似乎对于每个OIer来说都是一个永远的噩梦. 刚刚开始学dp的时候完全搞不明白(只是觉 ...

  7. HDU XXXX:求[L,R]的素数数量(数位DP)

    Problem G Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 131072/131072K (Java/Other) Total S ...

  8. 网络下载器 迅雷大众版 v7.9.42.5050 精简绿色版

    下载地址:点我 基本介绍 迅雷大众版是一款采用了先进的超线程技术基于网格原理,能够将存在于第三方服务器和计算机上的数据文件进行有效整合,通过这种先进的超线程技术,用户能够以更快的速度从这些第三方节点平 ...

  9. [Lydsy2017年4月月赛]抵制克苏恩题解

    考试的时候以为就是简单的概率期望题,考完后知道是简单的概率期望DP题,完美爆零. 这道题数据范围很小,很容易让人想到状压,不过貌似没什么可压的.那么只能说明这道题复杂度很高了,状态数组f[o][i][ ...

  10. Spring MVC源码(三) ----- @RequestBody和@ResponseBody原理解析

    概述 在SpringMVC的使用时,往往会用到@RequestBody和@ResponseBody两个注解,尤其是处理ajax请求必然要使用@ResponseBody注解.这两个注解对应着Contro ...