1 从http://search.maven.org/#search%7Cgav%7C1%7Cg%3A%22junit%22%20AND%20a%3A%22junit%22

上下载最新的junit包。

2 建立名为JunitTest的JavaProject,把下载的junit-4.12.jar添加到工程中

3 建立com.abc的package,在该package下建立Calculator.Java,用来实现加减乘除运算。

  1. package com.abc;
  2. publicclass Calculator {
  3. publicint add(inta,intb) {
  4. returna +b;
  5. }
  6. publicint minus(inta,intb) {
  7. returna - 1;  //故意写错,方便测试
  8. }
  9. publicint divide(inta,intb) {
  10. returna /b;
  11. }
  12. publicint mul(inta,intb) {
  13. returna *b;
  14. }
  15. }

4 创建测试

(1)右键点击要测试的类Calculator.java,“New”,“JUnit Test Case”

(2)这里有四个方法可选:setUpBeforeClass()和setUp()是用于测试之前的准备工作,区别在于setUpBeforeClass()是针对整个类的,只执行一次,setUp()是针对方法的,每个测试方法被执行之前都会先执行setUp();tearDownAfterClass()和tearDown()是用于测试之后释放资源的,区别在于tearDownAfterClass()是针对整个类的,只执行一次,tearDown()是针对方法的,每个测试方法被执行后都会执行tearDown()。

这里勾选setUpBeforClass()。

(3)这里可以选择要测试的方法。把四个运算方法都选上。

(4)点击finish后生成的代码如下图所示

(5)编写测试类代码

  1. package com.abc;
  2. importstatic org.junit.Assert.*;
  3. importorg.junit.Before;
  4. importorg.junit.Test;
  5. publicclass CalculatorTest {
  6. Calculatorcal;
  7. @Before
  8. publicvoid setUp()throws Exception{
  9. cal =newCalculator();
  10. }
  11. @Test
  12. publicvoid testAdd() {
  13. intres =cal.add(20, 10);
  14. assertEquals("加法错误",res, 30);
  15. }
  16. @Test
  17. publicvoid testMinus() {
  18. intres =cal.minus(20, 10);
  19. assertEquals("减法错误",res, 10);
  20. }
  21. @Test
  22. publicvoid testDivide() {
  23. intres =cal.divide(20, 10);
  24. assertEquals("除法错误",res, 2);
  25. res =cal.divide(20, 0);
  26. }
  27. @Test
  28. publicvoid testMul() {
  29. intres =cal.mul(20, 10);
  30. assertEquals("乘法错误",res, 200);
  31. }
  32. }

5 开始测试

右键点击Calculator,“Run As”,“JUnitTest”,报initializationError的错误

这个错误是因为少了junit-4.12.jar的两个依赖包:hamcrest-core-1.3.rc2.jar和hamcrest-library-1.3.rc2.jar。

从网络上下载这两个包并添加到工程中:

重新进行单元测试,结果如下:

上述结果显示了两个方法是正确的,一个方法是计算结果错误,另一个方法是编译错误。

点击testMinus,可以查看错误信息为计算结果应该为10却计算成了19。

点击testDivide,可以看到错误信息为除数不能为0。

Java笔记18:JUnit单元测试的更多相关文章

  1. day1 java基础回顾-Junit单元测试

    Junit单元测试框架的基本使用 一.搭建环境: 导入junit.jar包(junit4) 二.写测试类: 0,一般一个类对应一个测试类. 1,测试类与被测试类最好是放到同一个包中(可以是不同的源文件 ...

  2. java基础72 junit单元测试

    1.junit要注意的细节 1.如果junit测试一个方法,在junit窗口上显示绿色代表测试成功:如果显示红条,则代表测试方法出现异常不通过.    2.如果点击方法名.包名.类名.工程名运行jun ...

  3. 白盒测试笔记之:Junit 单元测试以及测试覆盖率

    单元测试: 单元测试是从代码层面验证代码的正确性. 一般考虑接口中的数据结构是否正确,变量的临界条件,如空字符串,空集合等. ​ Junit入门  参考: Junit 入门教程: https://ww ...

  4. JAVA自动化之Junit单元测试框架详解

    一.JUnit概述&配置 1.Junit是什么? Junit是一个Java 编程语言的开源测试框架,用于编写和运行测试.官网 地址:https://junit.org/junit4/ 2.Ma ...

  5. Thinking in Java——笔记(18)

    I/O The original byte-oriented library was supplemented with char-oriented, Unicode-based I/O classe ...

  6. Java中的Junit单元测试

    测试方法必须使用@Test进行修饰 测试方法必须使用public void 进行修饰,不能带任何的参数 新建一个源代码目录来存放我们的测试代码 测试类的包名应该和被测试类的包名一致 测试单元中的每个方 ...

  7. 解决Junit单元测试 找不到类 ----指定Java Build Path

    做junit 单元测试时,发现怎么执行都是以前编译过得代码. 最后找到原因了, src/test/java 编译完的.class路径是 Default output folder Default ou ...

  8. Java 工具 JUnit单元测试

    Java 工具 JUnit单元测试 @author ixenos 1.1.   JUnit单元测试框架的基本使用 一.搭建环境: 导入junit.jar包(junit4) 二.写测试类: 0,一般一个 ...

  9. Spring完全基于Java配置和集成Junit单元测试

    要点: 配置继承WebApplicationInitializer的类作为启动类,相当于配置web.xml文件 使用@Configuration注解一个类,在类中的方式使用@Bean注解,则表名该方法 ...

随机推荐

  1. zoj 3195

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=3320 离线算法RE了.. #include<stdio.h> #i ...

  2. 【hdoj_2391】FilthyRich

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2391 题目大意:给定一个矩阵,从左上角第一个元素开始到右下最后一个元素,寻找一条路线,使得路线经过的矩阵元 ...

  3. android之 Activity跳转出现闪屏

    原文:http://blog.csdn.net/az313/article/details/17321549 同一个应用,在不同手机上测试,Activity之间跳转出现闪屏,界面来回跳转…… 查阅网上 ...

  4. 64位直接加载个img 标签的src

  5. Supervisor-类unix系统下的进程控制工具

    如果你的英文足够好,请看官网的文档:http://supervisord.org/introduction.html 简介: Supervisor 类unix系统下的进程控制工具. 特性: 1.配置简 ...

  6. shell日志重定向到null

    用输出重定向符号> 即可,格式如下:shell命令 >/dev/null 若要将标准错误输出也一并重定向,如下:shell命令 >/dev/null 2>&1这样就不管 ...

  7. 使用jsonp形式跨域访问实现电商平台的左侧导航栏

    电商平台有个具备的左侧商品类目的导航栏的结构. 通过jsonp跨域访问电商平台的后台管理系统商品分类.(主要实现后台Java代码) 实现基本步骤: 1.在后台管理系统中准备相应的json数据. poj ...

  8. POJ 1985.Cow Marathon-树的直径-树的直径模板(BFS、DFS(vector存图)、DFS(前向星存图))

    Cow Marathon Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 7536   Accepted: 3559 Case ...

  9. 如何求先序排列和后序排列——hihocoder1049+洛谷1030+HDU1710+POJ2255+UVA548【二叉树递归搜索】

    [已知先序.中序求后序排列]--字符串类型 #1049 : 后序遍历 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho在这一周遇到的问题便是:给出一棵二叉树的前序和 ...

  10. 洛谷P2278 [HNOI2003] 操作系统

    题目传送门 分析:题目中提到了优先级,很显然这题要用优先队列+模拟.题目中很多细节需要注意,还是在代码中解释吧,这里我用的是手打的堆. Code: #include<bits/stdc++.h& ...