- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个带有 SLF4J 记录器实例的类:
public class MyClass {
private static final Logger log = LoggerFactory.getLogger(MyClass.class);
public void foo() {
log.warn("My warn");
}
}
我需要像这样用 JMockit 测试它:
@Test
public void shouldLogWarn(@Mocked Logger log) throws Exception {
new Expectations() {{
log.warn(anyString);
}};
MyClass my = new MyClass();
my.foo();
}
经过大量搜索后我发现,我需要以某种方式使用 MockUp。但无法准确了解。
顺便说一句,我使用的是最新版本的 JMockit(1.29),您无法再为最终静态字段setField(log)。
最佳答案
@Capturing
适用于这种情况的注释Indicates a mock field or a mock parameter for which all classes extending/implementing the mocked type will also get mocked.
Future instances of a capturing mocked type (ie, instances created sometime later during the test) will become associated with the mock field/parameter. When recording or verifying expectations on the mock field/parameter, these associated instances are regarded as equivalent to the original mocked instance created for the mock field/parameter.
这意味着如果您使用 @Capturing
而不是 @Mocked
对其进行注释,则在测试运行期间创建的每个 Logger
都将被与您注释的相关联。所以以下工作:
@Test
public void shouldLogWarn(@Capturing final Logger logger) throws Exception {
// This really ought to be a Verifications block instead
new Expectations() {{
logger.warn(anyString);
}};
MyClass my = new MyClass();
my.foo();
}
附带说明一下,如果您只想验证方法是否被调用,最好使用 Verifications相反,因为这就是它的目的。所以你的代码看起来像这样:
@Test
public void shouldLogWarn(@Capturing final Logger logger) throws Exception {
MyClass my = new MyClass();
my.foo();
new Verifications() {{
logger.warn(anyString);
}};
}
Logger
和 LoggerFactory
上使用 @Mocked
在某些情况下,@Capturing
由于注释工作方式的复杂性而无法按预期工作。幸运的是,您也可以通过在 Logger
和 LoggerFactory
上使用 @Mocked
来获得相同的效果,如下所示:
@Test
public void shouldLogWarn(@Mocked final LoggerFactory loggerFactory, @Mocked final Logger logger) throws Exception {
MyClass my = new MyClass();
my.foo();
new Verifications() {{
logger.warn(anyString);
}};
}
注意: JMockit 1.34 到 1.38 has a bug这会阻止它与 slf4j-log4j12
以及可能的 SLF4J 的其他依赖项一起使用。如果遇到此错误,请升级到 1.39 或更高版本。
关于java - 使用 JMockit 模拟和验证 SLF4J,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40660543/
我有这个抽象类: public abstract class Accessor { public U find(T id) { // let's say r
我正在尝试使用 JMockit 对 Android 应用程序进行单元测试。这有点棘手,因为在本地 JVM 中执行测试意味着所有 Android 类都是 stub ,但您可以模拟它们,这不是问题。 但现
public class HuronClassloader extends URLClassLoader { public HuronClassloader(Logger logger) {
我有一个正在 mock 的方法,以避免在单元测试期间进行网络调用,它看起来像这样: InputStream sendRequestAndReturnResponseStream(String para
我有这样的东西: new Expectations() {{ mock0.f(); mock1.f(); mock0.f(); mock1.f(); mock0
我已经将 JMockit 设置为与一些 JUnit 测试一起使用,也使用 Robolectric,但我遇到了错误。我主要使用 maven 来运行测试。 当我使用 mvn test 运行测试并且 jav
我正在将一些测试用例从 JMock 迁移到 JMockit。到目前为止,这是一段愉快的旅程,但是 JMock 中有一项我无法在 JMockit(版本 0.999.17)中找到的功能 我想检查模拟是否从
我不认为 minInvocation 或 maxInvocation 等同于 Mockito 中的 times() 。在那儿? 请看这个问题:Major difference between: Moc
当我使用 JUnit 5 和 JMockit 使用以下测试方法时,出现以下错误: JMockit 没有被初始化;请检查 -javaagent JVM 初始化参数是否被使用 这些是我创建并想要测试的类:
我长期以来一直在使用 JMockit。我想了解 @Tested 是如何工作的。 今天我尝试在我的测试类中使用它。我的理解是,无论我们想要测试什么类,我们都可以将其标记为@Tested。 让我对此行为感
我正在尝试使用 EMMA 来衡量一些使用 JMockit 的 JUnit 测试的覆盖率。但是当我在使用 EMMA 进行检测后尝试运行 JMockit 测试时,大约四分之一的测试失败并出现以下错误: c
我正在将用 JUnit 4 编写的单元测试转换为 JUnit 5。当被测试的方法调用静态方法时,我们使用 JMockit。 在 JUnit 4 中, @RunWith(JMockit.class) p
我在以下场景中使用 jmockit 时遇到问题。在网上查了一下,但还没有找到答案。 在记录阶段,我对部分模拟的对象设置期望。在执行此操作时,我想模拟具有单个参数的私有(private)方法。但我并不真
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我正在尝试使用以下代码使用 jmockit1.43 模拟 System.currentTimeMillis private static class SystemMock extends MockUp
当我尝试运行 Junit 测试用例时,我遇到了异常。 如果我正在更改类路径条目顺序,它工作正常,但 Jococo 覆盖不起作用。它正在挂起。 任何人都可以帮助解决这个问题。 java.lang.I
假设我的被测系统是这样的: public class SysUnderTest { public int foo() { Trouble trouble1 = new Trou
我正在我的应用程序中使用 JMockit 为 DAO 编写单元测试用例,为此我必须模拟 spring 的 jdbcTemplate,以便不会对数据库进行任何调用。我看过其他帖子/示例讨论模拟 DAO,
假设我的被测系统是这样的: public class SysUnderTest { public int foo() { Trouble trouble1 = new Trou
希望这里对某人来说是一个简单的问题...... 我正在使用 RAD 7.5.2,并且正在编写 Junit 测试。我用 JUnit 3 编写它们很好,然后我想模拟一些函数调用。所以我加载了 jmocki
我是一名优秀的程序员,十分优秀!