junit4的进一步探讨

上次只是大概记录了下junit4几个常见标签的用法。

在这篇文章中,我们来进一步分析junit4的用法。

1.断言

junit4中一个很常见的用法就是断言。说到断言,大家再熟悉不过了。不过也许有的朋友会有些疑问,为嘛有时候用assertEquals而有时候看到别人又用Assert.assertEquals()。其实两个的用法都是一样的,只是引入包的时候有点区别,只要你用心观察你会发现,用assertEquals时是“import static org.junit.Assert.*”,这是一个静态包含(static),是JDK5中新增的一个功能。也就是说assertEquals是assertEquals是Assert类中的一系列的静态方法,一般的使用方式是Assert. assertEquals(),但是使用了静态包含后,前面的类名就可以省略了,使用起来更加的方便。不过具体用哪个还是看个人习惯啦。

2.限时测试

有些程序的逻辑比较复杂,循环嵌套深,很有可能出现死循环。或者是测前端的时候有时候由于网速的原因,过了很长时间还是找不到某些页面元素。这时候我们可能希望程序会有某些处理机制。限时测试就是一个很好地解决方案。我们可以给我们的测试函数设定一个时间,超过了这个时间,就判定测试失败,并终止这个用例的执行。

要实现这一功能,给@Test标签加一个参数就行。

如:

@Test(timeout=1000)

public void test(){

....

}

以上表明如果程序在1000ms(注意这里的单位是ms),也就是1s内没有执行完,则test失败。

3.异常测试

有时候我们编写的函数需要抛出异常,那么我们在测试这个程序的时候肯定也就希望能捕获这个异常,如果没有捕获到,则说明测试失败。

@Test(expected=MyException.class)

public void test(){

}

4.Suite测试

请参照文章“用junit testSuite管理测试用例” http://www.cnblogs.com/weiweiyao/p/4092877.html

这个就不说了,之前写过。

5.参数化测试

你可能遇到过这样的函数,它的参数有许多特殊值,或者说他的参数分为很多个区域。举一个比较简单的例子吧,像如下函数:

public class Try {

public  int result=3;

public  int add(int n) {

result += n;

return result;

}

}

如果我想测试不同的输入值,则我需要写很多个@Test方法。如果测试的函数再复杂些,有各种边界值需要校验的话,那么你可能就需要写更多的@Test方法了。

比如:

@Test

public void test1(){

assertEquals(1,4);

}

@Test

public void test2(){

assertEquals(3,6);

}

但是如果用参数化测试的话,可以简化,我们只需要写一个测试函数,就可以把若干种情况作为参数传递进去,一次性的完成测试。

测试代码如下:

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;

import junit.framework.TestCase;

//步骤1.指定特殊的运行器Parameterized.class

@RunWith(Parameterized.class)

public class TryTest extends TestCase {

//步骤2:为测试类声明几个变量,分别用于存放期望值和测试所用数据。此处我只放了测试所有数据,没放期望值。

private int param,result;

//步骤3:申明构造函数

public TryTest(int param, int result) {

super();

this.param = param;

this.result = result;

}

//步骤4:定义测试数据的集合,该方法可以任意命名

//但是必须使用@Parameters标注进行修饰

//这个方法的框架就不予解释了,大家只需要注意其中的数据,是一个二维数组,数据两两一组

//每组中的这两个数据,一个是参数,一个是你预期的结果。

//比如我们的第一组{4, 7},4就是参数,7就是预期的结果。分别对应上面构造函数的param和result

@Parameters

public static  Collection testDate(){

Object[][] object = {

{ 1, 4},

{ 3, 6 },

{1,3}};

return Arrays.asList(object);

}

//步骤5:编写测试方法,使用定义的变量作为参数进行测试

//这里的编写方法和以前的测试方法一样

@Test

public void testAdd(){

Try test=new Try();

assertEquals(result,test.add(param));

}

}

测试结果:

(1,4)测试通过,(3,6)测试通过,(1,3)测试不通过,期望结果是3,实际结果却是4。

6.设置忽略某个测试用例

对于你想暂时不进行的test case, 在该方法前添加@Ignore

@Ignore("Not Ready to Run" )        
@Test     
public void test1() {        
        assertEquals(1, 4);        
}

时间: 2024-10-15 03:38:58

junit4的进一步探讨的相关文章

(十六)WebGIS中偏移补偿量引发的问题之探讨

1.背景 在上一章里讲解地图平移功能的实现时,我在最后提出了两个问题: A.在地图平移后,矢量图层的canvas的XY都发生了变化,此时根据地理坐标转换为屏幕坐标公式得出的屏幕坐标,在canvas上能将要素正确显示吗? B.矢量图层canvas的原点坐标XY有需要还原成初始的(0,0)的时候吗? 对这两个问题我给出的答案是:不能和需要. 在这一章里,我们将详细讲解得出这两个答案的原因. 2.何为偏移补偿量? 在地图平移时,我们做了两个操作:一个是对MapCanvas的原点坐标XY进行了变化,第二

(转)探讨12306两地三中心混合云架构

前言 2015年春节最大的特色就是“摇一摇”,微信红包在春晚摇一摇互动总量超过110亿次,峰值达8.1亿次/分钟,有185个国家传递微信祝福.支付宝钱包在除夕晚上8点达峰值,首页被点击的次数为8.832亿次/分钟.表面上来看“摇一摇”是在送红包,但从深层次的互联网思维来看,摇一摇的目的是要创造和凸显“移动支付”在互联网金融的价值链,甚至一带一路,将“移动支付”模式的业务,带出国门推向全球,此举对金融行业未来的生态影响意义重大. 摇一摇隐含的商业模式不是此篇文章讨论重点,在此要强调的是在云计算和大

全球导航网格码(GNGC)计算模型的进一步研究

全球导航网格码(GNGC)计算模型的进一步研究 李  滨 (北京大学遥感与地理信息系统研究所,北京 100871,[email protected]) 著名的数学软件Mathematica的发明人是数学家.物理学家.计算机学家沃尔夫勒姆博士(Stephen Wolfram,1959-).他在二零零二年出版了一本专著:<A New Kind of Science>.在这本书中他系统的表达了他的理念:自然界的本质是计算,但计算的本质必须用实验探索.无论是简单或复杂的数学问题(如对2开平方),还是普

NN:神经网络算法进阶优化法,进一步提高手写数字识别的准确率—Jason niu

上一篇文章,比较了三种算法实现对手写数字识别,其中,SVM和神经网络算法表现非常好准确率都在90%以上,本文章进一步探讨对神经网络算法优化,进一步提高准确率,通过测试发现,准确率提高了很多. 首先,改变之一: 先在初始化权重的部分,采取一种更为好的随机初始化方法,我们依旧保持正态分布的均值不变,只对标准差进行改动, 初始化权重改变前, def large_weight_initializer(self): self.biases = [np.random.randn(y, 1) for y in

.NET深入解析LINQ框架(五:IQueryable、IQueryProvider接口详解)

阅读目录: 1.环路执行对象模型.碎片化执行模型(假递归式调用) 2.N层对象执行模型(纵横向对比链式扩展方法) 3.LINQ查询表达式和链式查询方法其实都是空壳子 4.详细的对象结构图(对象的执行原理) 5.IQueryable<T>与IQueryProvider一对一的关系能否改成一对多的关系 6.完整的自定义查询 1]. 环路执行对象模型.碎片化执行模型(假递归式调用) 这个主题扯的可能有点远,但是它关系着整个LINQ框架的设计结构,至少在我还没有搞懂LINQ的本意之前,在我脑海里一直频

kafka数据可靠性深度解读

Kafka起初是由LinkedIn公司开发的一个分布式的消息系统,后成为Apache的一部分,它使用Scala编写,以可水平扩展和高吞吐率而被广泛使用.目前越来越多的开源分布式处理系统如Cloudera.Apache Storm.Spark等都支持与Kafka集成. 1 概述 Kafka与传统消息系统相比,有以下不同: 它被设计为一个分布式系统,易于向外扩展: 它同时为发布和订阅提供高吞吐量: 它支持多订阅者,当失败时能自动平衡消费者: 它将消息持久化到磁盘,因此可用于批量消费,例如ETL以及实

肯&#183;威尔伯的超个人心理学理论及其对佛教的阐释

2015-10-29                                                 原军超                                                 陈寿文                         陈寿文 陈寿文                                 微信号                                 chenshouwen1979 功能介绍               

冲刺二

小组讨论结果 经过今天的小组会议,小组各成员决定先进一步探讨项目的需求.因为我们明白要砍倒一棵树,磨刀才是前期的重中重之重,实际中也有不少以为前期需求没做好而,在项目后期推翻重做的例子.所以要清楚在接下来的日子里我们小组的成员会从各个方面了解好,在订餐这个场景中客户有什么样的痛点,而解决思路是如何. 现在小组内的分工如下: l  列志华也就是本人(零号) ---- 现阶段在设计数据库表,还有对小组其他成员所写的需求文档进行检查. l  韩麒麟(结对组壹) ---- 现阶段在和其他成员进行需求文档

1121 冲刺2

冲刺一 (Day 2) 小组讨论结果 经过今天的小组会议,小组各成员决定先进一步探讨项目的需求.因为我们明白要砍倒一棵树,磨刀才是前期的重中重之重,实际中也有不少以为前期需求没做好而,在项目后期推翻重做的例子.所以要清楚在接下来的日子里我们小组的成员会从各个方面了解好,在订餐这个场景中客户有什么样的痛点,而解决思路是如何. 现在小组内的分工如下: l  列志华也就是本人(零号) ---- 现阶段在设计数据库表,还有对小组其他成员所写的需求文档进行检查. l  韩麒麟(结对组壹) ---- 现阶段