曾经公司做过一个.net的项目,在项目开发的过程中。我们採用的是分层的开发方式,大家先在一起讨论接口, 然后讨论完以后,形成文档,然后依照文档进行开发!这样就有一个问题,你必需要保证你的接口是正确的。然后才干提供给其它人使用。

所以一定要对你写的方法进行单元測试。单元測试真的是非常方便!

如今的公司是开发java 项目的,开发过程也和.net的开发模式是一样的,所以说单元測试也成了必需品。

可是我们用的JUnit。

下边就给大家介绍一下JUnit的用法。

我们首先来建立一个项目。项目结构例如以下例如以下图所看到的!

然后倒入我们须要的jar包,我用的Myeclipse 。他集成了JUnit,所以说直接加入他的jar就能够了,在项目上单击右键。选择BuildPath 然后选择Libraries, 然后选择JUnit,他会有两个版本号,Junit3 和Junit 4然后选择一个, 本项目选择的是Junit3 ,加入完毕后, 项目中会多出一个Junit3的 一个库。

然后在项目的根文件夹下建一个Source Folder 例如以下图所看到的, 然后在建立一个和src 下边一样的包。这么做的目的是使下边要生成的測试类。不用引用对被測试类的依赖。他们生成的.class文件在同一个Bin文件夹下。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemhhbmdob25namllMDMwMg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

在我们的要測试的那个类上边单击右键, 然后选择New ,然后选择Others ,然后选择Junit Test Case。 然后Source folder 选择我们后来建立的測试的Source folder。然后将setUp和tearDown勾选上。

将我们我们要測试的那个类的全部的方法都勾选上,或者勾选我们要測试的方法就能够了!

然后选择完毕!

这样就会看到我们的測试类已经自己主动的为我们生成好了。

可是我们能够看到。自己主动为我们生成的測试方法。都是没有实现的,并且这些測试方法符合了一定的规范。

測试方法满足例如以下原则: 1)方法类型必须为public 2)返回值void 3)无參数 4)方法名必须以test开头或者以test结尾。可是建议使用前者!

所以接下来我们要自己写測试方法的实现了!

。例如以下所看到的。

package com.tgb.test;

import junit.framework.Assert;
import junit.framework.TestCase; public class CountMethodTest extends TestCase { /**
* setUp在每一个測试方法运行前都要运行 该方法
*/
protected void setUp() throws Exception {
super.setUp();
} /**
* tearDown 在每一个測试方法运行完毕后都要运行 该方法
*/
protected void tearDown() throws Exception {
super.tearDown();
} /**
* 測试目标类的add 方法
*/
public void testAdd() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
//该值为运行完目标类方法后,返回的实际值
int actual= cm.add(par1, par2);
// 推断方法的返回结果
Assert.assertEquals(3, actual);// 第一个參数是期望值,第二个參数是要验证的值
} public void testSubtract() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
int actual= cm.subtract(par1, par2);
assertEquals(3, actual);
} public void testMultiply() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
int actual= cm.multiply(par1, par2);
assertEquals(0, actual);
} public void testDiv() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
int actual= cm.div(par1, par2);
assertEquals(0, actual);
}
}

然后我们在该測试类的空白处单击右键选择 Run As 然后选择Junit Test 。这样我们就能够运行我们刚才写的单元測试了!

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemhhbmdob25namllMDMwMg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

能够看到測试结果例如以下。运行了四个方法,有一个错误的。能够看到打叉的那个失败了! 通过单元測试,我们能够非常快的发现我们的方法写的是否正确!

假设在測试的SourceFolder以下有多个单元測试类,我们想统一进行单元測试。你会怎么处理呢?我们能够一个个的去手动运行,然后在哪等着结果。是不是有点浪费时间呢。Junit 给我提供了一个更好的方法,我们在建立一个測试类。然后 该类的写法例如以下,这样我们就能够一次性的把全部的方法都运行了!

package com.tgb.test;

import junit.framework.Assert;
import junit.framework.TestCase; public class CountMethodTest extends TestCase { /**
* setUp在每一个測试方法运行前都要运行 该方法
*/
protected void setUp() throws Exception {
super.setUp();
} /**
* tearDown 在每一个測试方法运行完毕后都要运行 该方法
*/
protected void tearDown() throws Exception {
super.tearDown();
} /**
* 測试目标类的add 方法
*/
public void testAdd() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
//该值为运行完目标类方法后,返回的实际值
int actual= cm.add(par1, par2);
// 推断方法的返回结果
Assert.assertEquals(3, actual);// 第一个參数是期望值,第二个參数是要验证的值
} public void testSubtract() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
int actual= cm.subtract(par1, par2);
assertEquals(3, actual);
} public void testMultiply() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
int actual= cm.multiply(par1, par2);
assertEquals(0, actual);
} public void testDiv() {
int par1=3;
int par2=0;
CountMethod cm = new CountMethod();
int actual= cm.div(par1, par2);
assertEquals(0, actual);
}
}

Junit 的使用,非常方便的让我们測试类,可是他生成的測试方法体是空的,都须要自己写, 假设能想.Net 中那样,把測试方法体,大部分的内容都给你写好了就更好了!

三分钟掌握 JUnit3.0的更多相关文章

  1. 三分钟快速上手TensorFlow 2.0 (下)——模型的部署 、大规模训练、加速

    前文:三分钟快速上手TensorFlow 2.0 (中)——常用模块和模型的部署 TensorFlow 模型导出 使用 SavedModel 完整导出模型 不仅包含参数的权值,还包含计算的流程(即计算 ...

  2. 三分钟快速上手TensorFlow 2.0 (中)——常用模块和模型的部署

    本文学习笔记参照来源:https://tf.wiki/zh/basic/basic.html 前文:三分钟快速上手TensorFlow 2.0 (上)——前置基础.模型建立与可视化 tf.train. ...

  3. 三分钟快速上手TensorFlow 2.0 (上)——前置基础、模型建立与可视化

    本文学习笔记参照来源:https://tf.wiki/zh/basic/basic.html 学习笔记类似提纲,具体细节参照上文链接 一些前置的基础 随机数 tf.random uniform(sha ...

  4. x01.TextProc: 两三分钟完成的一个小工具

    在工作中,遇到这么个问题,需要将 Excel 表中类似 2134-1234-4456 的商品编号输入到单位的程序中,而程序只认 213412344456 这种没有 ‘-’ 的输入.数量比较多,一笔一笔 ...

  5. unity3d 三分钟实现简单的赛车漂移

    提到赛车游戏,大家最关心的应该就是漂移吧?! 从学unity开始,我就一直在断断续续的研究赛车 因为自己技术太烂.悟性太差等原因,我走了不少弯路 也许你会说,网上那么多资料,你不会查啊 是啊!网上一搜 ...

  6. 三分钟部署Laxcus大数据管理系统

    Laxcus是Laxcus大数据实验室历时五年,全体系自主设计研发的国内首套大数据管理系统.能够支撑百万台级计算机节点,提供EB量级存储和计算能力,兼容SQL和关系数据库.最新的2.x版本已经实现对当 ...

  7. JUnit三分钟教程 ---- 实际应用

    JUnit三分钟教程 ---- 实际应用 摘自http://lavasoft.blog.51cto.com/62575/65775   接上文"JUnit三分钟教程 ---- 快速起步&qu ...

  8. JUnit三分钟教程 ---- 快速起步

    JUnit三分钟教程 ---- 快速起步 摘自http://lavasoft.blog.51cto.com/62575/65625/ JUnit是个好东西,做大点的项目离不开这东西,实际中用的时候也因 ...

  9. 三分钟浅谈TT猫的前端优化

    首先看一张访问TT猫首页的截图: 测试环境为谷歌浏览器,暂且不讨论其它浏览器,截图下方我们可以观察到以下参数: DOMContentLoaded:1.42s | Load:2.31s 以上参数是在CT ...

随机推荐

  1. 【转】正确理解PHP程序编译时的错误信息

    我们编写程序时,无论怎样小心谨慎,犯错总是在所难免的.这些错误通常会迷惑PHP编译器.如果开发人员无法了解编译器报错信息的含义,那么这些错误信息不仅毫无用处,还会常常让人感到沮丧. 编译PHP脚本时, ...

  2. hdu 3948(后缀数组+RMQ)

    题意:求一个串中有多少不同的回文串. 分析:这一题的关键是如何去重,我表示我现在还没理解为什么这样去重,先放这里过两天再看!! //不同回文子串数目 #include <iostream> ...

  3. useful-scripts

    最近在github看到关于一些比较好的java相关脚本.vcs脚本.shell脚本.怕以后忘记了,在此做个备注. 原链接为:https://github.com/oldratlee/useful-sc ...

  4. Int.Parse()、Convert.toInt32()和(int)区别

    通过网上的查询从而了解了Int.Parse().Convert.toInt32()和(int)区别. 一.定义上的差别 int类型表示一种整型,.NET Framework 类型为 System.In ...

  5. Casperjs/PhantomJs 中文网站截图乱码

    使用CasperJs进行自动化测试中文网站的时候发现中文网站截图会出现乱码的现象,中文汉字被一个个小方框代替 查找了一些资料发现是因为Linux服务器上没有安装中文字体导致的,Linux如何安装中文字 ...

  6. Web服务器(Apache)虚拟主机的配置

    一.定义    所谓虚拟主机是指在一台服务器里运行几个网站,提供WEB.FTP.Mail等服务.    二.虚拟主机的实现方法有三种:    基于IP的方法,基于主机名的方法和基于端口的法官法.    ...

  7. codevs1796-最小完全图

    表示第一篇就是水题. 根据Prim的思想,我们可以证明:dis ( a , b ) > max { a b 最小生成树路径上的边权 } 把所有边sort一遍用并查集维护就可以了 #include ...

  8. Python多线程和Python的锁

    Python多线程 Python中实现多线程有两种方式,一种基于_thread模块(在Python2.x版本中为thread模块,没有下划线)的start_new_thread()函数,另一种基于th ...

  9. Python闭包与javascript闭包比较

    实例一 python def line_conf(): def line(x): return 2*x+1 print(line(5)) # within the scope     line_con ...

  10. Buffer -nodejs

    纯 JavaScript 对 Unicode 友好但是无法很好地处理二进制数据.当我们面对类似 TCP 流或文件系统时,是需要处理八位流的.Node 有几种操作.创建以及消费八位流的策略.原始数据保存 ...