javaweb简单测试框架

2023年4月26日14:36:47

刚开始学习javaweb,学的迷迷糊糊,始终不明白注解的作用还有框架到底是个啥,在自己敲完这Check小测试方法之后懂了许多

下面这个就是Check测试类,在使用时在所检查的代码上面写一个@Check 就能用了(和之前用过的@Test 好像),运行之后会创建一个bug.txt文本,来体现有什么异常,有几个异常等信息

package day01;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

//@author 靳嘉豪
//creates 2023-04-25-22:04
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Check {
}
package day01;

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.lang.reflect.Method;

//@author 靳嘉豪
//creates 2023-04-25-21:51 
public class TestCheck {
    public static void main(String[] args) throws IOException {
//        1.创建计算机对象
        Calculator c = new Calculator();
//        2.获取字节码文件对象
        Class cls = c.getClass();
//        3.获取所有方法
        Method[] methods = cls.getMethods();

        int number = 0;
        BufferedWriter bw = new BufferedWriter(new FileWriter("bug.txt"));
        for (Method method : methods) {
            //        4.判断方法上是否有Check注解
            if (method.isAnnotationPresent(Check.class)) {
                //        5.有的话执行
                try {
                    method.invoke(c);
                } catch (Exception e) {
                    //        6.捕获异常
//                    记录到文件中
                    number++;
                    bw.write(method.getName() + "出现异常了");
                    bw.newLine();
                    bw.write("异常的名称" + e.getCause().getClass().getCanonicalName());
                    bw.newLine();
                    bw.write("异常的原因"+e.getCause().getMessage());
                    bw.newLine();
                    bw.write("---------");
                }

            }
        }
        bw.write("本次测试一共出现"+number+"次异常");

        bw.flush();
        bw.close();
    }
}

以下是被检测的代码

package day01;

//@author 靳嘉豪
//creates 2023-04-25-21:53 
public class Calculator {
    //    加法
    @Check
    public void add() {
        System.out.println("1 + 0=" + (1 + 0));
    }
    @Check
    //    减法
    public void sub() {
        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));
    }
}

在TestCheck类中运行过后就会创建出一个bug.txt文本,如下图所示(他检测出来了div这个方法里面出现分母为零的情况)

 

 其实如果嫌麻烦的话可以吧异常名称和异常原因写到一起(突然明白API的重要性)

  bw.write("异常的名称/异常的原因" + e.getCause());

输出这个

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值