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 Check {
}
测试类的代码如下
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.lang.reflect.Method;
public class TestCheck {
public static void main(String[] args) throws IOException {
//创建需要测试的对象
Calculator c = new Calculator();
//获取字节码文件
Class c_Class = c.getClass();
//获取所有方法
Method[] methods = c_Class.getMethods();
int num = 0;//记录出现异常的次数
//创建输入流对象记录异常日志
BufferedWriter bw = new BufferedWriter(new FileWriter("C:\\Users\\酷酷的龙\\Desktop\\bug.txt"));
//遍历所有方法
for(Method method:methods){
//判读方法上是否有Check注解
if(method.isAnnotationPresent(Check.class)){
//有,执行方法
try {
method.invoke(c);
} catch (Exception e) {
//记录日志
num++;
bw.write(method.getName()+"方法出现了异常");
bw.newLine();
bw.write("异常的名称"+e.getCause().getClass().getSimpleName());
bw.newLine();
bw.write("异常的原因"+e.getCause().getMessage());
bw.newLine();
bw.write("===========================");
bw.newLine();
}
}
}
bw.write("本次测试一共出现了"+num+"次异常");
bw.flush();
bw.close();
}
}
需要测试的方法前面必须加上注解
需要测试的代码如下
public class Calculator {
@Check
public void add(){
String a = null;
a.toString();
System.out.println("1+0="+(1+0));
}
@Check
public void resart(){
System.out.println("1-0="+(1-0));
}
@Check
public void mul(){
System.out.println("1*0="+(1*0));
}
@Check
public void div(){
System.out.println("1/0="+(1/0));
}
@Check
public void show(){
System.out.println("永无bug");
}
}
运行结果
会在指定的地方生成一个bug.txt(异常日志)