给你的项目添加一个灵活的“开关”

简介:   年后项目提测了两次,每次提测都是通宵达旦完成~第二次通宵的原因主要可以用一个字来形容:等。  项目中对接了一个代付通道,每次测试代付功能都是发起代付请求之后,需要等十几到二十几分钟才能返回代付结果,甚至期间通道偶尔会出现一些问题,更尴尬的是等了好长时间,返回的结果是代付失败(代付通道测试环境返回的代付结果都是随机的)。

 年后项目提测了两次,每次提测都是通宵达旦完成~第二次通宵的原因主要可以用一个字来形容:等。

 项目中对接了一个代付通道,每次测试代付功能都是发起代付请求之后,需要等十几到二十几分钟才能返回代付结果,甚至期间通道偶尔会出现一些问题,更尴尬的是等了好长时间,返回的结果是代付失败(代付通道测试环境返回的代付结果都是随机的)。


 这时候就找到一个办法就是在代付的位置加上一个开关,需要模拟代付成功的时候可以打开,走正常流程的时候就关闭,类似于Mock,可以自由控制我们测试自己的代码的时候不受第三方的影响。


这好办,我在代码里是这么干的:


public class PayServiceImpl implements PayService{
    protected final static boolean isOpenMockPaySuccess = true; // 模拟代付成功的开关
    /**
     * 代付请求
     * @return
     */
    public boolean payRequest(){
        if(isOpenMockPaySuccess){
            return true;//如果开关打开,模拟代付请求成功
        }else{
            //执行正常的代付请求逻辑
        }
    }
    /**
     * 代付结果查询
     * @return
     */
    public boolean payQuery(){
        if(isOpenMockPaySuccess){
            return true;//如果开关打开,模拟代付结果成功
        }else{
            //执行正常的代付结果查询逻辑
        }
    }
}


 这样就能实现上面说的效果了,无论代付通道需要多长的处理时间,有没有挂掉,我们都不需要关注,只需要专注于测试自己的逻辑。


 看到这里您可能以为这就OK了,但是这么做有一个致命的缺点,就是安全性。


 测试无误的代码都是随时可以上线的,假如上面的代码测试无误,那上线之后如果忘记关上开关,那是不是每一笔代付都默认成功啦(其实都没有提交)?


 所以为项目加一个开关的想法是好的,但是这个开关最好是关闭状态的,不影响正常逻辑,只有在开关需要打开的时候才去打开,并且可以动态关闭并且不修改代码。


 这时就可以使用读取自定义环境变量的形式来设置开关,比如:

protected final static boolean isOpenMockPaySuccess = Boolean.parseBoolean(System.getProperty("isOpenMockPaySuccess", "false")); // 模拟代付成功的开关


  默认是关闭(false),如果需要打开开关,则需要在jvm启动参数中添加isOpenMockPaySuccess参数,值为true:


-Xmx128 -Xms64 -Xmn32m -Xss16m -DisOpenMockPaySuccess=true


  这样,测试的时候可以在测试环境打开开关,生产环境也不会执行威胁生产环境安全的代码,保证程序在测试环境顺利测试,在生产环境安全运行。

相关文章
|
7天前
|
人工智能 运维 安全
|
5天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
6天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
621 23
|
6天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
12天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
983 110
|
5天前
|
人工智能 数据可视化 数据挖掘
Quick BI 体验&征文有奖!
瓴羊生态推出Quick BI 征文激励计划,鼓励用户分享数据分析实践经验与技术洞察,征集高质量原创文章。内容围绕AI功能体验与BI案例实践,设季奖、年奖及参与奖,优秀作者可获现金奖励、产品内测资格及官方认证形象。投稿截止至2026年3月31日。
Quick BI 体验&征文有奖!