- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Mockito 的新手,我在 Eclipse 中将它与 JUnit4
一起使用。我试图模拟我的方法如下:CartLine line = mock(CartLine.class);
然后我得到: FileNotFoundException
由调用所谓的模拟方法引起,如下面的堆栈跟踪所示。这是预期的行为吗?我使用 Mockito 正是为了避免使用整个环境。
堆栈跟踪:
java.io.FileNotFoundException: cart.properties (file not found)
at java.io.FileInputStream.open(Native Method)
at java.io.FileInputStream.<init>(Unknown Source)
at com.mycompany.cart.util.ResourceFactory.getFileInputStream(ResourceFactory.java:119)
at com.mycompany.cart.util.ResourceFactory.getProperties(ResourceFactory.java:295)
at com.mycompany.cart.CartSettings.tryLoadSettings(CartSettings.java:215)
at com.mycompany.cart.CartSettings.<init>(CartSettings.java:72)
at com.mycompany.cart.CartSettings.<clinit>(CartSettings.java:60)
at com.mycompany.cart.CartLine.<clinit>(CartLine.java:59)
at sun.reflect.GeneratedSerializationConstructorAccessor4.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at org.objenesis.instantiator.sun.SunReflectionFactoryInstantiator.newInstance(SunReflectionFactoryInstantiator.java:40)
at org.objenesis.ObjenesisBase.newInstance(ObjenesisBase.java:59)
at org.mockito.internal.creation.jmock.ClassImposterizer.createProxy(ClassImposterizer.java:128)
at org.mockito.internal.creation.jmock.ClassImposterizer.imposterise(ClassImposterizer.java:63)
at org.mockito.internal.creation.jmock.ClassImposterizer.imposterise(ClassImposterizer.java:56)
at org.mockito.internal.creation.CglibMockMaker.createMock(CglibMockMaker.java:23)
at org.mockito.internal.util.MockUtil.createMock(MockUtil.java:26)
at org.mockito.internal.MockitoCore.mock(MockitoCore.java:51)
at org.mockito.Mockito.mock(Mockito.java:1243)
at org.mockito.Mockito.mock(Mockito.java:1120)
at com.redacted.ml.TestConfToJasper.mockCartLine(TestConfToJasper.java:173)
at com.redacted.ml.TestConfToJasper.mockCartLines(TestConfToJasper.java:131)
at com.redacted.ml.TestConfToJasper.testBuildUCSElement(TestConfToJasper.java:75)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
1249 [main] WARN com.redacted.cart.util.ResourceFactory - Can not find property file: cart.properties
1249 [main] FATAL com.redacted.cart.CartSettings - Can not load cart properties!
编辑:这是完整的测试代码:
private static final CartLine mockCartLine(LineType type) {
CartLine line = mock(CartLine.class);
when(line.getLineType()).thenReturn(type);
return line;
}
调用者:
private static final CartLine[] mockCartLines() {
CartLine[] lines = new CartLine[10];
int i=0;
lines[i++] = mockCartLine(LineType.FO);
[...]
return lines;
}
调用者:
@Test
public void testBuildUCSElement() {
ConfToJasper ctj = new ConfToJasper(confML);
CartController controller = mock(CartController.class);
CartDataObject dataObject = mock(CartDataObject.class);
CartLine[] lines = mockCartLines();
[...]
}
(我不是此代码的创建者)
最佳答案
在我看来,您的 CartLine 中有某种静态初始化程序试图打开文件流。
我强烈建议您通过删除此类静态初始化程序逻辑来清理代码,使其易于单元测试。 (通常改为实例方法更合适)
或者您的测试资源中可能有一个虚拟的“cart.properties1”,以便您的 CartLine 可以读取它。
或者您可以考虑使用PowerMock来看看它是否有助于避免此类问题(无论如何我怀疑......)
关于java - 莫基托 : mock() calls real method,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21831257/
我有 TaskType 类。它有方法 public Class getTypeParameters() { return typeParameters; } 接下来我想模拟这个类并模拟这个方法
我有一个类,其方法impersonate会抛出UnsupportedOperationException。所以我只想模拟这个唯一的方法。我知道我可以使用 Mockito.spy 来做到这一点。 Ses
应该如何更改此代码以便它不会抛出以下异常? ArgumentCaptor argument = forClass(Date.class); verify(ps, times(0)).setDate(a
如何验证没有调用模拟对象的方法? 我想要这样的东西: Mockito.assertNoOneMethodWasCalled(myMockObject); 最佳答案 如果您想检查是否根本没有发生交互:
我有一个方法: void putObject( param) 在我模拟此方法的地方进行了一些测试,但我想知道,如何验证该方法是使用特定类的参数调用的?试图以这种方式做到这一点: verify(foo)
在我试图测试的类中,我有 @Resource 注释的依赖项,我正在尝试编写一些测试并想要注入(inject)该依赖项,我的问题是,在模拟依赖项之后,它是值为null private SOAPServi
我失败了:processStandaloneCancelAuthRequest(00, "true")java.lang.IllegalArgumentException: 参数类型不匹配....错误
我正在使用mockito进行单元测试。考虑以下代码片段 ThirdPartyClass tpo = mock(ThirdPartyClass.class); doNothing().when(tpo)
我正在尝试为我的 Controller 类编写单元测试。但它不是模拟 EmployeeBussinessLogic,而是调用真正的方法调用。 public class Controller {
Class A { public B makeB(int q) { return new B(q); } public boolean evaluate(int
我是 Mockito 的新手,我在 Eclipse 中将它与 JUnit4 一起使用。我试图模拟我的方法如下:CartLine line = mock(CartLine.class);然后我得到: F
我在 Spring Web 模型- View - Controller (MVC) 框架应用程序中使用 Mockito(根据 MIT 许可证发布的 Java 开源测试框架)进行了 junit 测试我在
我正在做一个单元测试,它调用一个类并检查该类中的方法是否已使用某些参数调用。这些参数之一是 LocalDateTime.now() . 我的问题是,当时间控制回到我的 JUnit 测试时,时间已经过去
我在使用两个 void 方法时遇到问题。在 encouragingVenturesScoring 中,我遵循了这个答案 mocking an arraylist that will be looped
我正在尝试使用mockito来模拟服务。然而,我没有找到一种方法来告诉mockito,给定一个类的实例返回给我相同的实例: 类似于: given(service.add(any(Individua
是否可以在mockito中使用when-return返回不同的类型。 我的功能 m.findDocument(id) 返回一个基于id的文档,我将其转换为字符串以供进一步处理。但是,为了进行测试,我从
我是一名优秀的程序员,十分优秀!