首页 > 其他分享 >21_Spring_日志框架和测试支持

21_Spring_日志框架和测试支持

时间:2023-07-30 12:56:03浏览次数:45  
标签:21 Spring springframework context org test import 日志 junit

21_Spring_日志框架和测试支持

spring5框架自带了通用的日志封装,也可以整合自己的日志

1)spring移除了 LOG4jConfigListener,官方建议使用log4j2

2)spring5整合log4j2

导入log4j2依赖

  1.      <!--log4j2 依赖-->
    
  2.      <!--<dependency>
    
  3.          <groupId>org.apache.logging.log4j</groupId>
    
  4.          <artifactId>log4j-core</artifactId>
    
  5.          <version>2.14.0</version>
    
  6.      </dependency>-->
    
  7.      <!--slf4-impl 包含了log4j2 依赖-->
    
  8.      <dependency>
    
  9.          <groupId>org.apache.logging.log4j</groupId>
    
  10.         <artifactId>log4j-slf4j-impl</artifactId>
    
  11.         <version>2.14.0</version>
    
  12.         <scope>test</scope>
    
  13.     </dependency> 
    

在resources目录下准备log4j2.xml的配置文件

  1.  <Appenders>
    
  2.      <Console name="Console" target="SYSTEM_OUT">
    
  3.          <PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p
    
    %c{1}:%L - %msg%n" />
  4.      </Console>
    
  5.  </Appenders>
    
  6.  <Loggers>
    
  7.      <Root level="debug">
    
  8.         <AppenderRef ref="Console" />
    
  9.     </Root>
    
  10. </Loggers>
    

spring5关于测试工具的支持

整合junit4

依赖的jar

  1.      <!--Junit4单元测试-->
    
  2.      <dependency>
    
  3.          <groupId>junit</groupId>
    
  4.          <artifactId>junit</artifactId>
    
  5.          <version>4.13.1</version>
    
  6.          <scope>test</scope>
    
  7.      </dependency>
    
  8.      <!--spring test测试支持包-->
    
  9.      <dependency>
    
  10.         <groupId>org.springframework</groupId>
    
  11.         <artifactId>spring-test</artifactId>
    
  12.         <version>5.3.5</version>
    
  13.         <scope>test</scope>
    
  14.     </dependency>
    

测试代码编写方式

  1. package com.msb.test;
  2. import com.msb.config.SpringConfig;
  3. import com.msb.service.AccountService;
  4. import org.junit.Test;
  5. import org.junit.runner.RunWith;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.context.ApplicationContext;
  8. import
    org.springframework.context.annotation.AnnotationConfigApplicationContext;
  9. import org.springframework.context.support.ClassPathXmlApplicationContext;
  10. import org.springframework.lang.Nullable;
  11. import org.springframework.test.context.ContextConfiguration;
  12. import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
  13. /**
    • @Author: Ma HaiYang
    • @Description: MircoMessage:Mark_7001
  14. */
  15. @RunWith(SpringJUnit4ClassRunner.class)// 指定测试支持类
  16. @ContextConfiguration("classpath:applicationContext.xml")// 指定核心配置文件位置
  17. public class Test2 {
  18. @Autowired // 注入要获取的bean
    
  19. private  AccountService accountService;
    
  20. @Test()
    
  21. public void testTransaction(){
    
  22.     int rows = accountService.transMoney(1, 2, 100);
    
  23.     System.out.println(rows);
    
  24. }
    
  25. }

整合junit5

依赖的jar

  1.      <!--junit5单元测试-->
    
  2.      <dependency>
    
  3.          <groupId>org.junit.jupiter</groupId>
    
  4.          <artifactId>junit-jupiter-api</artifactId>
    
  5.          <version>5.7.0</version>
    
  6.          <scope>test</scope>
    
  7.      </dependency>
    

测试代码编写方式

  1. package com.msb.test;
  2. import com.msb.service.AccountService;
  3. import org.junit.jupiter.api.Test;
  4. import org.junit.jupiter.api.extension.ExtendWith;
  5. import org.springframework.beans.factory.annotation.Autowired;
  6. import org.springframework.test.context.ContextConfiguration;
  7. import org.springframework.test.context.junit.jupiter.SpringExtension;
  8. import org.springframework.test.context.junit.jupiter.SpringJUnitConfig;
  9. /**
    • @Author: Ma HaiYang
    • @Description: MircoMessage:Mark_7001
  10. */
  11. /使用ExtentWith和ContextConfiguration注解/
  12. /*@ExtendWith(SpringExtension.class)
  13. @ContextConfiguration("classpath:applicationContext.xml")*/
  14. // 使用复合注解
  15. @SpringJUnitConfig(locations = "classpath:applicationContext.xml")
  16. public class Test3 {
  17. @Autowired // 注入要获取的bean
    
  18. private  AccountService accountService;
    
  19. @Test
    
  20. public void testTransaction(){
    
  21.     int rows = accountService.transMoney(1, 2, 100);
    
  22.     System.out.println(rows);
    
  23. }
    
  24. }

标签:21,Spring,springframework,context,org,test,import,日志,junit
From: https://www.cnblogs.com/01way/p/17591295.html

相关文章

  • springboot logback 配置文件 自定义logback配置文件
    logging:level:#配置全部的调试级别#root:trace#配置具体包路径下的调试级别com.example.springboot03:tracepattern:#默认控制台输出格式console:'%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-ddHH:mm:ss.SSSXXX}}){faint}%clr(${LOG_......
  • 3_Spring_IOC原理分析_重要
    3_Spring_IOC原理分析_重要IOC底层原理1XML解析技术读取配置文件将上面的信息读取进入程序 对象的ID,一个是对象的类的全路径名2反射技术实例化对象,放到容器中获得类的字节码Classclazz=Class.forName("com.msb.dao.impl.EmpDaoImpl")通过字节码实例化对象Ob......
  • 2_Spring_IOC概念引入_重要
    2_Spring_IOC概念引入_重要简单的说就是,创建对象的权利,或者是控制的位置,由JAVA代码转移到spring容器,由spring的容器控制对象的创建,就是控制反转,spring创建对象时,会读取配置文件中的信息,然后使用反射给我们创建好对象之后在容器中存储起来,当我们需要某个对象时,通过id......
  • 6_Spring_Bean的自动装配
    6_Spring_Bean的自动装配bean自动装配通过property标签可以手动指定给属性进行注入我们也可以通过自动转配,完成属性的自动注入,就是自动装配,可以简化DI的配置准备实体类packagecom.msb.bean;/**@Author:MaHaiYang@Description:MircoMessage:Mark_7001......
  • 5_Spring_Bean的生命周期
    5_Spring_Bean的生命周期bean从创建到销毁经历的各个阶段以及每个阶段所调用的方法1通过构造器创建bean实例     执行构造器2为bean属性赋值            执行set方法3初始化bean                调......
  • 4_Spring_XML方式实现DI
    4_Spring_XML方式实现DIspring中的Bean的管理:Bean(汉译咖啡豆).又称JAVABean.其实就是JAVA程序程序中的一个个对象,所以Bean的管理其实就是spring对于JAVA程序中的对象的管理管理的内容是什么1对象的创建 IOCIOC 叫做控制反转,就是Spring给我们创建对象,然后我们直......
  • 9_Spring_JDK动态代理
    9_Spring_JDK动态代理代理模式是通过代理对象访问目标对象,这样可以在目标对象基础上增强额外的功能,如添加权限,访问控制和审计等功能。房产中介代替业主卖房静态代理静态代理中代理类与被代理类都需要实现同一个接口,这就说明我们的一个静态代理类只能代理一个类,并且还要事先......
  • 8_Spring_注解方式管理bean
    8_Spring_注解方式管理bean1注解方式创建对象IOC导入依赖aop@Component  放在类上,用于标记,告诉spring当前类需要由容器实例化bean并放入容器中该注解有三个子注解@Controller 用于实例化controller层bean@Service    用于实例化service层bean@Repositor......
  • 7_Spring_使用外部属性配置文件
    7_Spring_使用外部属性配置文件spring容器可以读取.properties属性配置文件,可以将文件中的信息注入给bean例如,引入Druid数据源,配置连接池信息1 导入Druid依赖和mysql-connector依赖<dependency><groupId>com.alibaba</groupId><artifa......
  • 13_Spring_AOPXML方式实现_了解
    13_Spring_AOPXML方式实现_了解1、创建两个类,增强类和被增强类,创建方法见之前的代码2、在spring配置文件中创建两个类对象 3、在spring配置文件中配置切入点<aop:config><!--切入点--><aop:pointcutid="pointCutAdd"expression="execution......