当前位置: 首页 > news >正文

基于注解一个简单的测试框架

首先准备一个被测试的类

package com.yunji.test02;/*
 @Author wanghongyuan
  @Date 2021/1/28 
 
*/

public class Calculator {
    @Check
    public void Add(){ int a = 1/0;System.out.println("1+0:"+(1+0)); }
    @Check
    public void Sub(){ System.out.println("1+0:"+(1-0));}
    @Check
    public void Div(){ System.out.println("1+0:"+(1/0));}
    @Check
    public void mul(){ System.out.println("1+0:"+(1*0));}
}

定义一个注解

package com.yunji.test02;/*
 @Author wanghongyuan
  @Date 2021/1/28 
 
*/

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

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Check {

}

定义一个执行注解的主方法

package com.yunji.test02;/*
 @Author wanghongyuan
  @Date 2021/1/28 
 
*/

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

public class TestCheck {
    public static void main(String[] args) throws Exception {
        //创建一个需要被测试的对象。
        Calculator c = new Calculator();
        //获取字节码文件
        Class aClass = c.getClass();
        //获取所有方法
        Method[] methods = aClass.getMethods();
        int count = 0;
        BufferedWriter bw = new BufferedWriter(new FileWriter("C:\\Users\\why\\Desktop\\untitled\\src\\test\\java\\com\\yunji\\test02\\bug.txt"));
        for (Method method : methods) {
            //判断方法是否有我们标注的注解
            if (method.isAnnotationPresent(Check.class)){
                //有,我们执行方法
                try {
                    method.invoke(c);
                } catch (Exception e) {
                    //捕获异常
                    e.printStackTrace();
                    //记录到文件中
                    count++;
                    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("本次测试共出现"+count+"次异常");
        bw.flush();
        bw.close();
    }
}

最终执行结果

1+0:1
1+0:0
java.lang.reflect.InvocationTargetException
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at com.yunji.test02.TestCheck.main(TestCheck.java:28)
Caused by: java.lang.ArithmeticException: / by zero
	at com.yunji.test02.Calculator.Add(Calculator.java:9)
	... 5 more
java.lang.reflect.InvocationTargetException
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at com.yunji.test02.TestCheck.main(TestCheck.java:28)
Caused by: java.lang.ArithmeticException: / by zero
	at com.yunji.test02.Calculator.Div(Calculator.java:13)
	... 5 more

Process finished with exit code 0

文件记录的格式

Add方法出现异常
异常的名称是:ArithmeticException
异常的原因是:/ by zero
------------------------------
Div方法出现异常
异常的名称是:ArithmeticException
异常的原因是:/ by zero
------------------------------
本次测试共出现2次异常

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 数据库(一)
  • 数据库(二)
  • 数据库(三)
  • 数据库(四)
  • 数据库(五)
  • 数据库(六)
  • 数据库(七)
  • 0205
  • 数据库(八)
  • 数据库(九)
  • Httprunner使用指南
  • JDBC(一)
  • JDBC(二)
  • JDBC(三)
  • JDBC(五)
  • [原]深入对比数据科学工具箱:Python和R 非结构化数据的结构化
  • 【Redis学习笔记】2018-06-28 redis命令源码学习1
  • 2017 前端面试准备 - 收藏集 - 掘金
  • CSS3 聊天气泡框以及 inherit、currentColor 关键字
  • css布局,左右固定中间自适应实现
  • export和import的用法总结
  • gf框架之分页模块(五) - 自定义分页
  • Java的Interrupt与线程中断
  • Laravel Mix运行时关于es2015报错解决方案
  • MySQL Access denied for user 'root'@'localhost' 解决方法
  • MYSQL 的 IF 函数
  • QQ浏览器x5内核的兼容性问题
  • React-生命周期杂记
  • Shell编程
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • 想写好前端,先练好内功
  • 一道面试题引发的“血案”
  • 最近的计划
  • 如何用纯 CSS 创作一个菱形 loader 动画
  • !!java web学习笔记(一到五)
  • ###51单片机学习(1)-----单片机烧录软件的使用,以及如何建立一个工程项目
  • #android不同版本废弃api,新api。
  • #微信小程序(布局、渲染层基础知识)
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (Pytorch框架)神经网络输出维度调试,做出我们自己的网络来!!(详细教程~)
  • (二开)Flink 修改源码拓展 SQL 语法
  • (离散数学)逻辑连接词
  • (七)微服务分布式云架构spring cloud - common-service 项目构建过程
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (四)JPA - JQPL 实现增删改查
  • (算法二)滑动窗口
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (原創) 如何解决make kernel时『clock skew detected』的warning? (OS) (Linux)
  • *setTimeout实现text输入在用户停顿时才调用事件!*
  • .NET Core、DNX、DNU、DNVM、MVC6学习资料
  • .net dataexcel 脚本公式 函数源码
  • .net framework 4.0中如何 输出 form 的name属性。
  • .net php 通信,flash与asp/php/asp.net通信的方法
  • .net 打包工具_pyinstaller打包的exe太大?你需要站在巨人的肩膀上-VC++才是王道
  • .NET 中的轻量级线程安全