一、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. hgoi#20190516

    T1-Buying A House 给你一个长度为n的序列a,给你目标房子m,最多花的钱k 如果a[i]为0,这座房子无法购买,否则可以购买,求能买的距离目标房子最近的房子,输出最小距离 两座房子之间 ...

  2. Node.js Windows Example

    Firstly, download the msi file from https://nodejs.org/en/ Second, click the msi file to install nod ...

  3. 手把手教你实现"短信轰炸"

    手把手教你实现"短信轰炸" 我这里采用简单易懂的语言--"Python3"来实现   实现前的准备:             1,电脑,谷歌浏览器 2,pyth ...

  4. 2019年6月份,阿里最新Java高频面试真题汇总,仅供参考(附福利)

    目录 技术一面(23问) 技术二面(3大块) JAVA开发技术面试中可能问到的问题(17问) JAVA方向技术考察点(33快) 项目实战(7大块) 必会知识(48点) 面试小技巧 注意事项 1. 阿里 ...

  5. 什么是Task

    什么是Task Task是.Net4.0新增用来处理异步编程的,叫做基于“任务编程模型”,任务其实是架构在线程之上的,具体操作的时候还是由线程去执行的,任务的管控有点类似于线程池,程序中开10个Tas ...

  6. 【Aizu - 0033】Ball (简单搜索)

    -->Ball 原文是日语,这里直接写中文了 Descriptions: 如图所示,容器中间有一枢轴,下方分为两路.容器上方开口,从1到10连续编号的小球从容器开口A放入.通过调整枢轴E的方向, ...

  7. Linux命令学习-history命令

    Linux中,history命令的作用是显示历史记录和执行过的命令. 查看历史所有命令执行记录 history 查看最近的13条历史执行命令 history 13 执行历史记录中,序号为123的命令 ...

  8. String到底在内存中是如何存储的

    String会出现在哪些地方 方法内的局部string 类内的字段String static string 容器中存储的string String数组 那么String的位置会影响其存储方式吗? 显然 ...

  9. 【tf.keras】在 cifar 上训练 AlexNet,数据集过大导致 OOM

    cifar-10 每张图片的大小为 32×32,而 AlexNet 要求图片的输入是 224×224(也有说 227×227 的,这是 224×224 的图片进行大小为 2 的 zero paddin ...

  10. 通讯(tarjan缩点)(20190716NOIP模拟测试4)

    B. 通讯   题目类型:传统 评测方式:文本比较  内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目描述 “这一切都是命运石之门的选择.” 试图研制时间机器的机关SERN截获了 ...