主要内容
注解定义到方法上的应用扩展。通过在目标类中给需要测试的方法加上自定义注解,从而起到标识的作用,再定义一个测试类写测试方法判断目标类中方法是否为待测方法,对其进行测试并将测试结果写到日志中。解决了通过main方法一个一个调用待测方法运行效率低和调多个待测方法而一旦其中一个方法出现异常报错而耽误后续待测方法执行的问题。
反射
我们在定义好一个Java类之后可对该类成分,可以获取到每个具体属性的值,使用构造方法和普通方法。Java中有个概念是万事万物皆对象,事实上所有的类,类中的属性,类中的方法或者其他成分也可以作为对象,这些对象我们可通过Java中的反射机制得到。具体得通过Class类中的方法实现。
注解
java5之后新增的技术,可用在各种元素(类,构造器,属性,方法)上通过声明注释来实现不同需求。Java源代码中就可看到很多内置注解,本文例子需要使用到自定义的注解。
自定义注解:
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**内置注解表示以下自定义的注解在运行时生效*/
@Retention(RetentionPolicy.RUNTIME)
/**内置注解表示以下自定义注解在方法上使用*/
@Target(ElementType.METHOD)
public @interface Test {
}
测试框架:
public class MyJunit {
public static void main(String[] args) {
//记录需要测试的方法总数
int methodCount = 0;
//记录错误的方法总数
int expCount = 0 ;
try {
//准备一个文件输出流,用于记录程序执行过程中的异常信息
BufferedWriter bw = new BufferedWriter(new FileWriter("log.txt"));
//获取待测试类的Class对象(反射机制)
Class clz = UserTest.class;
//创建目标类型的实例对象
Object obj = clz.newInstance();
//获取待测类的所有方法对象(包含了其父类的方法)
Method[] methods = clz.getMethods();
bw.write("===========测试开始=====================");
for (Method m : methods) {
try {
//如果方法上面有Test注解则为目标测试方法
if(m.isAnnotationPresent(Test.class)) {
//需要测试方法总数增加
methodCount++;
//方法执行
m.invoke(obj);
}
} catch (Exception e) {
//异常方法计数器递增
expCount++;
bw.write(m.getName()+"出现异常");
bw.newLine();
bw.write("类型:"+e.getCause().getClass());
bw.newLine();
bw.write("原因:"+e.getCause().getMessage());
bw.newLine();
//方法之间的分隔线
bw.write("---------------");
bw.newLine();
}
}
bw.write("======测试结束=======");
bw.newLine();
bw.write("已测试方法数:"+methodCount+",其中异常方法:"+expCount);
bw.flush();
bw.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}