一、安装JUnitGenerator V2.0。

  1、通过网络安装。如下

  2、手动下载插件安装。插件下载:https://plugins.jetbrains.com/idea/plugin/3064-junitgenerator-v2-0 。安装如下图所示:

  3、安装完成重启IDEA,即可使用。

二、修改JUnitGenerator V2.0的配置。

  1、自动生成测试代码和java类在同一包下,不匹配maven项目标准测试目录。

     修改Output Path为:${SOURCEPATH}/../../test/java/${PACKAGE}/${FILENAME},

       Default Template选择JUnit 4。

  2、修改测试用例模板。模板中生成的package的包名需去掉test。

三、生成JUnit4测试用例。

  方法一:在待编写测试的java类源码块上按快捷键Alt + Insert。选择JUnit Test->JUnit 4。

  方法二、在待编写测试的java类源码块上按快捷键Ctrl + Shift + T。

  根据需要修改相关测试用例

  方法三:光标定位到待编写测试的java类源码块,选择code->Generate,后面的步骤和方法1一样。

  最终生成的用例如下:

四、注意。

  IDEA自带的JUnit插件和JUnitGeneratorV2.0插件都要勾选上,若只勾选JUnit可能导致无法自动生成测试文件,

  若只勾选JUnitGenerator V2.0可能导致生成的测试文件无法运行

实体类junit测试用例生成

package com.wms;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map; /**
* Created by Administrator on 2017/4/8.
*/
public class Test { private static final StringBuilder sb = new StringBuilder(); public static void writeClass(String classStr, OutputStreamWriter out) {
try {
Class clz = Class.forName(classStr);
// Method[] methods = clz.getDeclaredMethods();
// for (Method method : methods) {
// String methodName = method.getName();
// Class[] params = method.getParameterTypes();
// for (Class param : params) {
// System.out.println(param.getName());
// }
// }
Field[] fields = clz.getDeclaredFields(); for (Field field : fields) {
Class c = field.getType();
// System.out.println(c.isInterface());
// System.out.println(c.getName());
// Class cc = Class.forName(c.getName());
// Object o = cc.newInstance();
//只写入set方法即可 out.write(setMethod(classStr, getParam(c, field.getName()), field.getName()));
} } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
} public static Map<String, Object> getParam(Class clz, String field) { Map<String, Object> map = new HashMap<String, Object>();
boolean isReference = false;
String result = ""; String className = clz.getName();
String clzName = className;
if (className.contains(".")) {
clzName = className.substring(className.lastIndexOf(".") + 1);
}
clearSb(sb);
if (clz.isInterface()) {
result = null;
} else if (className.startsWith("[L")) {
clzName = clzName.replaceAll(";", "");
sb.append(clzName).append("[] o = ").append("new ").append(clzName).append("[]{};");
result = sb.toString();
isReference = true;
} else if (clz == String.class) {
sb.append("\"").append(field).append("\"");
result = sb.toString();
} else if (clz == Integer.class || clz == int.class) {
result = "1";
} else if (clz == Long.class || clz == long.class) {
result = "1L";
} else if (clz == Float.class || clz == float.class) {
result = "1.1f";
} else if (clz == Double.class || clz == double.class) {
result = "1.1";
} else if (clz == Short.class || clz == short.class) {
result = "(short)1";
} else if (clz == Boolean.class || clz == boolean.class) {
result = "true";
} else if (clz == char.class || clz == Character.class) {
result = "\'1\'";
} else if (clz == byte.class || clz == Byte.class) {
result = "(byte)1";
} else {
sb.append(clzName).append(" o = ").append("new ").append(clzName).append("();");
result = sb.toString();
isReference = true;
} map.put("result", result);
map.put("isReference", isReference); return map;
} public static String setMethod(String classStr, Map<String, Object> map, String field) {
clearSb(sb);
classStr = classStr.substring(classStr.lastIndexOf(".") + 1);
boolean isReference = (Boolean) map.get("isReference");
String result = (String) map.get("result");
String str = firstLowerToUpper(field);
sb.append("\t");
sb.append("@Test").append("\n");
sb.append("\t");
sb.append("public void testSet").append(str).append("()").append("\n");
sb.append("\t");
sb.append("{").append("\n");
sb.append("\t").append("\t");
sb.append(classStr).append(" obj = new ").append(classStr).append("();").append("\n");
sb.append("\t").append("\t"); if (isReference) {
sb.append(result).append("\n");
result = "o";
sb.append("\t").append("\t");
} sb.append("obj.set").append(str).append("(").append(result).append(");").append("\n");
sb.append("\t").append("\t");
sb.append("assertTrue(").append(result).append(" == obj.get").append(str).append("());")
.append("\n");
sb.append("\t");
sb.append("}").append("\n").append("\n");
return sb.toString();
} public static String firstLowerToUpper(String field) {
return field.substring(0, 1).toUpperCase() + field.substring(1);
} public static void createTestFile(String projectPath, String[] pkgs, boolean rebuild) {
OutputStreamWriter out = null;
for (String pkg : pkgs) { String testPkgPath = checkTestPackage(projectPath, pkg);
String srcPkgPath = getJavaPackagePath(projectPath, pkg); File file = new File(srcPkgPath);
for (File file1 : file.listFiles()) { String className = getClassName(file1.getName());
File testFile = new File(getTestFile(testPkgPath, className));
if (!testFile.exists() || rebuild) {
try {
//0. 创建测试用例文件
testFile.createNewFile(); //1. 写入测试用例类的包名
out = new FileWriter(testFile);
out.write(packageLine(pkg)); //2. 写入junit测试用例用到的包
out.write(importJunitClassLine()); //3. 写入测试用例类名
out.write(startClassNameLine(className + "Test")); //4. before,after方法写入
// out.write(beforeMethod());
// out.write(afterMethod()); //5. 写入测试方法
writeClass(getClass(pkg, className), out); // 类结束
out.write(endClassNameLine());
out.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (out != null) {
try {
out.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
} } /**
* 检查测试类路径下的指定包是否存在,不存在则创建
*
* @param projectPath
* @param pkg
* @return
*/
public static String checkTestPackage(String projectPath, String pkg) {
String dstPath = getTestPackagePath(projectPath, pkg);
File f = new File(dstPath);
if (!f.exists()) {
f.mkdirs();
}
return dstPath;
} /**
* 获取测试类的全路径名
*
* @param dstPackage
* @param className
* @return
*/
public static String getTestFile(String dstPackage, String className) {
clearSb(sb);
sb.append(dstPackage).append(File.separator).append(className).append("Test.java");
return sb.toString();
} /**
* 包声明行
*
* @param pkg
* @return
*/
public static String packageLine(String pkg) {
clearSb(sb);
sb.append("package ").append(pkg).append(";");
sb.append("\n").append("\n");
return sb.toString();
} /**
* junit类导入行
*
* @return
*/
public static String importJunitClassLine() {
clearSb(sb);
sb.append("import org.junit.Test;").append("\n");
sb.append("import org.junit.Before;").append("\n");
sb.append("import org.junit.After;").append("\n").append("\n").append("\n");
sb.append("import static org.junit.Assert.*;").append("\n").append("\n");
return sb.toString();
} /**
* 类开始
*
* @param fileName
* @return
*/
public static String startClassNameLine(String className) {
clearSb(sb);
sb.append("public class ").append(className).append("\n");
sb.append("{").append("\n");
return sb.toString();
} /**
* 类结束
*
* @return
*/
public static String endClassNameLine() {
return "\n}";
} /**
* beforeMethod
*
* @return
*/
public static String beforeMethod() {
clearSb(sb);
sb.append("\n").append("\t").append("@Before").append("\n");
sb.append("\t").append("public void before()").append("\n");
sb.append("\t").append("{").append("\n");
sb.append("\t").append("}").append("\n");
return sb.toString();
} /**
* afterMethod
*
* @return
*/
public static String afterMethod() {
clearSb(sb);
sb.append("\n").append("\t").append("@After").append("\n");
sb.append("\t").append("public void after()").append("\n");
sb.append("\t").append("{").append("\n");
sb.append("\t").append("}").append("\n");
return sb.toString();
} /**
* 获取类全名,含有包
*
* @param pkg
* @param className
* @return
*/
public static String getClass(String pkg, String className) {
return pkg + "." + className;
} /**
* 获取类名,不含包
*
* @param fileName
* @return
*/
public static String getClassName(String fileName) {
return fileName.replace(".java", "");
} /**
* 获取java源文件路径下的指定包
*
* @param projectPath
* @param pkg
* @return
*/
public static String getJavaPackagePath(String projectPath, String pkg) {
String packagePath = pkg.replaceAll("\\.", "/");
return projectPath + "/src/main/java" + File.separator + packagePath;
} /**
* 获取java测试类路径下的指定包
*
* @param projectPath
* @param pkg
* @return
*/
public static String getTestPackagePath(String projectPath, String pkg) {
String packagePath = pkg.replaceAll("\\.", "/");
return projectPath + "/src/test/java" + File.separator + packagePath;
} /**
* 清空StringBuilder
*
* @param sb
*/
public static void clearSb(StringBuilder sb) {
sb.delete(0, sb.length());
} public static void main(String[] args) throws IOException {
String projectPath = "D:/data/IDEA workspace/wms-web";
String[] pkgs = new String[]{"com.wms.junit"}; createTestFile(projectPath, pkgs, true);
//loadClass("com.wms.junit.Person", null);
} }

IDEA Junit4配置的更多相关文章

  1. Spring项目使用Junit4测试配置

    我们经常要写junit测试,在不启动整个web项目的情况下,测试自己的service实现或者是dao实现,我们来充分利用下junit4的强大功能. 1.junit4的测试类 import java.u ...

  2. JUnit4.13环境配置

    Junit 4.13环境配置 JUnit是一个强大的单元测试工具.它可以针对某一个特定类的所有方法进行精确打击.这个东西具体怎么使用,留在以后说.这次给大家说说idea下配置JUnit环境的方法. 1 ...

  3. SpringMVC+Hibernate+Junit4+json基本框架近乎0配置

    公司是做APP开发的,须要后台来提供接口,于是乎,这个任务就交给我,经过重复的尝试,学习和參考别人的demo,最终搭出自己还算惬意的框架.SpringMVC+Sping3+Hibernate4+Jun ...

  4. IDEA 配置Junit4

    Junit4 主要用来执行java程序的单元测试: 1 安装junit4插件 因为我安装过了,没有安装的再输入框搜索,然后安装就行 2 选择默认使用Junit4 3 红框中的test去掉,变为“$en ...

  5. 当使用junit4 对spring框架中controller/service/mapper各层进行测试时,需要添加的配置

    @RunWith(SpringJUnit4ClassRunner.class) @WebAppConfiguration @ContextConfiguration(locations = {&quo ...

  6. java:Mybatis框架1(基本配置,log4j,Junit4(单元测试))

    1.mybatis01: db.properties: driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/test userna ...

  7. 使用Junit4对web项目进行测试(一)Junit初配置

    Junit测试用例不是用来证明你是对的,而是用来证明你没有错 1.功能   -在项目未在浏览器运行之前对获得的结果和预期的结果进行比较调试,减少BUG和发布时的修复工作 2.测试类和代码类应分开存放. ...

  8. junit4进行单元测试

    一.前言 提供服务的时候,为了保证服务的正确性,有时候需要编写测试类验证其正确性和可用性.以前的做法都是自己简单写一个控制层,然后在控制层里调用服务并测试,这样做虽然能够达到测试的目的,但是太不专业了 ...

  9. EhCache的配置

    JPA和Hibernate的二级缓存都是这样做的 代码目录: 这是基础的jar包,如果少的话,再去maven下载 <!-- Spring --> <dependency> &l ...

随机推荐

  1. 【读书笔记】iOS-MVC

    用户的每一个动作都是以一个View的Action方式传递给Controller,然后,Controller再发送消息通知Model做出响应的逻辑处理,当Model层面上的业务逻辑处理有了结果之后,Mo ...

  2. python之装饰器(函数)

    1. 装饰器 遵循的原则: 开闭原则:   对功能的扩展开放 对代码的修改是封闭 # 通用装饰器写法 # 存在的意义: 在不破坏原有函数和原有函数调用的基础上,给函数添加新的功能. def wrapp ...

  3. 交叉编译器 arm-linux-gnueabi 和 arm-linux-gnueabihf 的区别

    交叉编译器 arm-linux-gnueabi 和 arm-linux-gnueabihf 的区别 自己之前一直没搞清楚这两个交叉编译器到底有什么问题,特意google一番,总结如下,希望能帮到道上和 ...

  4. JMeter 参数化之利用JDBCConnectionConfiguration从数据库读取数据并关联变量

    参数化之利用DBC Connection Configuration从数据库读取数据并关联变量   by:授客 QQ:1033553122 1.   下载mysql jar包 下载mysql jar包 ...

  5. 国网SGCC_UAP 反编译.class文件源代码

    SGCC_UAP和eclipse操作方式差不多,对于用惯了IDEA和Android Studio的人来说非常不方便,按住Ctrl点击类名不能查看源码. 因为jar包下都是.class文件,所以需要安装 ...

  6. web应用

    实现HttpServlet的Web应用 <dependency> <groupId>javax.servlet</groupId> <artifactId&g ...

  7. spring cloud 配置文件application.yml和bootstrap.yml 的定位,区别和联系总算是有一点明白了

    最近在启用springcloud配置中心server的东西,在整理属性资源的时候,突然发现:用了这么久的springboot,为什么会配置两个属性文件同时存在(application.yml/prop ...

  8. 针对模拟滚动条插件(jQuery.slimscroll.js)的修改

    在开发过程中程序员总会碰到产品经理提出的各种稀奇古怪的需求,尽管有些需求很奇葩,但不得不说有些须有还是能指引我们不断的学习与进步,最近在工作中就碰到这种问题.需求是要求在各主流浏览器上使用自定义的滚动 ...

  9. 转:SQL Server中服务器角色和数据库角色权限详解

    当几个用户需要在某个特定的数据库中执行类似的动作时(这里没有相应的Windows用户组),就可以向该数据库中添加一个角色(role).数据库角色指定了可以访问相同数据库对象的一组数据库用户. 数据库角 ...

  10. Qt实现同步(阻塞式)http get等网络访问操作

    Qt的网络操作类是异步(非阻塞的),但有时想做一些阻塞的事情就不方便了,可用如下几行代码轻松实现: QByteArray MyNetworkAccess::get(const QString & ...