码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • spring 单元测试为 logback 添加环境变量


    场景描述

    spring 项目中配置了 logback 收集日志,同时使用 @SpringBootTest 做单元测试。此时就报错了,文件找不见。

    ERROR in ch.qos.logback.core.rolling.RollingFileAppender[file] - Failed to create parent directories for [/home/zhu/app/logs/2022-09-07.log]
    ERROR in ch.qos.logback.core.rolling.RollingFileAppender[file] - openFile(null,true) call failed. java.io.FileNotFoundException: /home/zhu/app/logs/2022-09-07.log (No such file or directory)


    原因

    logback-spring.xml 文件中这么写的,bosc.rec.logSavePath 指定保存日志文件,可以在 application.yml 指定。

    
    <configuration scan="false" packagingData="true">
        <springProperty scope="context" name="LOG_HOME" source="bosc.rec.logSavePath" />
      	
    configuration>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    # application.yml
    bosc:
      rec:
        logSavePath: ${LOG_SAVE_PATH:/home/zhu/app/logs}
    
    • 1
    • 2
    • 3
    • 4

    当单元测试启动时先加载 logback 的配置,再执行测试 case。日志文件找不到,就会抛出上面的异常。而且使用 @Before, @BeforeAll 或者 static 方法,在内部 System.setProperty() 设置环境变量的方式也都不能解决问题。因为这些方法的执行都晚于 logback 配置的加载。


    解决办法

    直接上代码。

    public class PropertyExtension implements BeforeAllCallback {
      @Override
      public void beforeAll(ExtensionContext context) {
        System.setProperty("LOG_SAVE_PATH", "/Users/mac/Downloads/bosc/logs");
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    @ExtendWith(PropertyExtension.class)
    @SpringBootTest(classes = JobManageApplication.class)
    class ScenePipelineRepositoryImplTest {
    
      @Autowired
      ScenePipelineRepository repository;
    
      @Test
      public void save_ScenePipeline_succeed() {
    			// 内容省略
      }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    啰嗦几句

    之所以抛出异常是因为使用 @SpringBootTest 做单元测试,这个注解会在执行测试 case 时会启动整个 spring 服务,所以会执行 spring 的初始化过程,加载一大堆的东西,从而包括了 logback 这玩意。

    但这样使用是不合理的:

    原因一:单测只测一个功能点,有必要把整个服务都启动吗?又不是做集成测试。

    原因二:假如服务中有定时任务 或者 向其他服务发请求的功能,那么这个任务也会运行,这是单测不想看到的现象。

    @SpringBootTest 适合做集成测试,测试成功后采用 @ignore 将测试类注解掉。

    spring 三层结构,每层都有单测,每层测试的目的和方式都不一样。

    曾今写过的一篇单测博客

    要让团队成员都遵守一些规矩还是有些挑战的。

  • 相关阅读:
    从零开始学WEB前端——HTML理论讲解
    (九)集合 - List
    Python:线性查找法
    「网页开发|前端开发|Vue」06 公共组件与嵌套路由:让每一个页面都平等地拥有导航栏
    叉车数字化安全管理平台,安全管控升级,打造智慧监管新模式
    腾讯云服务器4核8G配置有哪些?多少钱一年?
    A Philosophy of Software Design读书笔记——模块的接口要通用,实现要深入
    江森自控×实在智能丨RPA一天完成20+人工作量,为制造业赋能
    环信IM集成教程——Web端UIKit快速集成与消息发送
    MySQL提示sql_mode=only_full_group_by解决办法
  • 原文地址:https://blog.csdn.net/yy_diego/article/details/126743074
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号