sql 注射

所以,我欠吉姆道歉。 他编写了一个有效的模拟和JUnit测试,我在回顾中告诉他,我认为它没有达到他的预期。 当我错了时,这种情况对我来说就像是一个错误 。 称它为理想的意外副作用。

假设您有以下两类:

 public class Service { private String name; private Widget widget; public Service(String name, Widget widget) { this .name = name; this .widget = widget; } public void execute() { widget.handle(name); }  }  public interface Widget { void handle(String thing);  } 

那里没什么令人兴奋的…

现在,让我们尝试使用Mockito测试(此处为JUnit 5)测试服务:

 @ExtendWith (MockitoExtension. class )  class ServiceTest { @Mock private Widget widget; @InjectMocks private Service service = new Service( "Joe" , widget); @Test void foo() { service.execute(); verify(widget).handle( "Joe" ); }  } 

测试通过。 但是应该吗?

对我来说, @InjectMocks批注旨在作为一种工厂方法来创建依赖于模拟值的东西,在测试中使用@Mock表示。 这就是我通常使用的方式,并且我也希望生态系统中的所有对象都是使用构造函数注入构建的。

这是一个很好的设计原则,但不是工具功能的定义!

应用此批注的外观与在注释字段的过程@InjectMocks ,并采取不同的路径,如果它的null比,如果它已经初始化。 对于null路径是一种声明式构造函数注入方法如此纯粹,我完全不认为注入模拟可能意味着对现有对象执行此操作。 该文档也不太清楚这一点。

  • 如果没有对象,则@InjectMocks必须创建一个

    • 它使用可以提供的最大构造函数
  • 如果有一个对象,它将尝试通过setters来填充模拟
  • 如果没有设置器,它会尝试通过直接设置字段来强制破解模拟,迫使它们一路被访问

最重要的是, @InjectMocks静默@InjectMocks失败,因此您可能会在不知道的情况下进行神秘的测试失败。

更重要的是,有些人在Mockito Runner顶部的测试中使用MockitoAnnotations.initMocks()调用,这会导致各种奇怪的事情!!! 认真的家伙,永远不要打电话。

得到教训

呃,对不起,吉姆!

@InjectMocks注释确实会尽其所能执行最有用的操作,但是场景越复杂,预测就越困难。

在我看来,使用两种横切技术初始化对象是一种危险且难以理解的方法,但是,如果有记录的话,它可能比其他方法更好。 添加评论!

也许需要某种@InjectWithFactory ,您可以在其中声明一个接收所需@InjectWithFactory的方法,并在构造时使用@Mock对象调用该方法,以便您填充其余测试上下文中的任何其他参数。

或者,也许我们只是习惯了这项工作,而忘记了它是否易于理解。

最终思想

我通过创建测试并调试Mockito库以找到其实现结果的方法,了解了Mockito在上面所做的工作。 我强烈建议您以这种方式浏览您最常用的库。 您将学到一些有用的东西!

翻译自: https://www.javacodegeeks.com/2019/11/a-surprising-injection.html

sql 注射

sql 注射_令人惊讶的注射相关推荐

  1. 詹姆斯高斯林_詹姆斯·高斯林(James Gosling):Oracle的表现“令人惊讶的是” 用Java

    詹姆斯高斯林 1月27日将是Oracle收购Sun Microsystems的四周年. 从一开始,许多人就怀疑这家前软件公司处理Java的适用性. 而且,随之而来的指称是缺乏对开放源代码的支持以及对遗 ...

  2. 老spring3.2版本 redistemplate 报错_卡普空“令人惊讶”的老系列新作,会是《恐龙危机》吗?...

    如今,卡普空又表示正在开发一款"令人惊讶"的老系列作品,不知道<恐龙危机>的机会又有多大呢? 在2018年的TGA前夕,卡普空资深制作人竹内润接受了日本游戏媒体Fami ...

  3. PostgreSQL 10.1 手册_部分 II. SQL 语言_第 9 章 函数和操作符_9.4. 字符串函数和操作符...

    9.4. 字符串函数和操作符 9.4.1. format 本节描述了用于检查和操作字符串值的函数和操作符.在这个环境中的串包括所有类型character.character varying和text的 ...

  4. 【实战】轻轻松松使用StyleGAN(一):创建令人惊讶的黄种人脸和专属于自己的老婆动漫头像

    NVIDIA(英伟达)开源了StyleGAN,用它可以生成令人惊讶的逼真人脸:也可以像某些人所说的,生成专属于自己的老婆动漫头像.这些生成的人脸或者动漫头像都是此前这个世界上从来没有过的,完全是被&q ...

  5. Java中一个令人惊讶的bug

    点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 今天分享一个JDK中令人惊讶的BUG,这个BUG的神奇之处在于,复 ...

  6. 2040张图片训练出的ViT,准确率96.7%,连迁移性能都令人惊讶 | 南京大学

    晓查 发自 凹非寺 量子位 | 公众号 QbitAI ViT在计算机视觉领域取得了巨大的成功,甚至大有取代CNN之势. 但是相比CNN,训练ViT需要更多的数据,通常要在大型数据集JFT-300M或至 ...

  7. boost::safe_numerics模块实现混合类型产生令人惊讶的结果的测试程序

    boost::safe_numerics模块实现混合类型产生令人惊讶的结果的测试程序 实现功能 C++实现代码 实现功能 boost::safe_numerics模块实现混合类型产生令人惊讶的结果的测 ...

  8. 令人惊讶的手机端实时 4K 风格迁移!谷歌又出牛文

    Joint Bilateral Learning for Real-time Universal Photorealistic Style Transfer 本文是Boston & Pixel ...

  9. 灰度董事总经理:BTC突破2万美元并不令人惊讶

    灰度投资(Grayscale Investments)董事总经理Michael Sonnenshein表示,对于灰度,BTC突破2万美元大关不令人惊讶,因为该资产仍处于初期阶段.Sonnenshein ...

最新文章

  1. Hadoop数据收集与入库系统Flume与Sqoop
  2. Web前端框架与类库的思考
  3. 一. DotNet MVC4.0+EasyUI Web简单框架-前言
  4. CSDN企业数字化之路 ——「低代码」发展研讨会北京站现场实录大放送
  5. 《Splunk智能运维实战》——第1章 游戏时间——导入数据 1.1 简介
  6. LVS负载均衡群集之NAT模型DR模型
  7. 03C++语言对C的增强——实用性、变量检测、struct类型、C++中所有变量和函数都必须有类型、bool类型、三目运算符...
  8. 关于小米手机网站抢购的一点技术分析
  9. 微信公众平台二次开发技术文档
  10. Sql server添加示例数据库Northwind
  11. 涉及到各种场景-英语小记-最爱的一篇
  12. Adaboost 算法的公式推导与讲解
  13. 用 GreaseMonkey (油猴)解码 TinyURL
  14. 将Windows驱动程序从一台计算机复制到另一台计算机
  15. MATLAB7程序在哪,这个程序在MATLAB 7.0中为什么运行不起来 那个工具箱怎么装
  16. 各省、自治区、直辖市分行业新三板上市公司数统计(不含香港、澳门、台湾)
  17. 苹果三代耳机_苹果三代蓝牙无线耳机
  18. 我的旅途-嵌入式软件工程师成长之路(一)
  19. 基于单片机的存钱罐系统设计(#0465)
  20. CF 400D Dima and Bacteria

热门文章

  1. LCS(2021牛客多校4)
  2. D - Covering HDU - 6185(未解决完)
  3. 牛客题霸 [比较版本号] C++题解/答案
  4. YbtOJ#482-爬上山顶【凸壳,链表】
  5. jzoj6375-华灵「蝶妄想」【结论题】
  6. jzoj5353-村通网【最小生成树】
  7. JoyOI(TYVJ)1061-Mobile Service【线性dp】
  8. ssl2348-连接格点【图论,最小生成树,并查集】
  9. 【dfs】栅栏的木料(2012特长生 T4)
  10. HDU5528 - Count a * b