- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试模拟这样的类(感谢谷歌的代码设计,很难在测试环境中使用):
GoogleAuthorizationCodeGrant googleAuthorizationCodeGrant = EasyMock.createMock(GoogleAuthorizationCodeGrant.class);
然后我将设置一个模拟方法调用,如下所示:
AccessTokenResponse accessTokenResponse = new AccessTokenResponse();
EasyMock.expect(googleAuthorizationCodeGrant.execute()).andReturn(accessTokenResponse);
但它会抛出异常,因为在 googleAuthorizationCodeGrant.execute() 期间,它会尝试运行 GoogleAuthorizationCodeGrant.execute() 中的实际代码。我在这里错过了什么吗?我希望 cglib 代理包装这个类并重写它的方法而不执行任何操作,因为我不希望它们在模拟时实现。不需要保留任何业务逻辑,因为我正在定义各种方法调用的行为。
编辑
注意 - 我认为这里存在一些困惑。异常抛出于:
EasyMock.expect(googleAuthorizationCodeGrant.execute()).andReturn(accessTokenResponse)
当我将模拟置于重播模式时,不会,因为我从未真正到达该代码。引发异常的原因是 GoogleAuthorizationCodeGrant 的成员为 null,并且在 .execute() 上调用了该成员的方法。如果我使用 new 运算符实例化 GoogleAuthorizationCodeGrant,则该成员不会为 null。但是我不明白为什么 EasyMock 会在类上像这样工作,因为我希望它创建一个代理来包装实现而不执行任何操作。
这是堆栈跟踪:
java.lang.NullPointerException
at com.google.api.client.auth.oauth2.draft10.AccessTokenRequest.executeUnparsed(AccessTokenRequest.java:451)
at com.google.api.client.auth.oauth2.draft10.AccessTokenRequest.execute(AccessTokenRequest.java:475)
at uk.co.domain.service.google.GmailContactPollerTest.testDoPoll(GmailContactPollerTest.java:64)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)
at org.junit.runners.ParentRunner.run(ParentRunner.java:300)
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)
最佳答案
我不确定您是否重播了该模拟实例。如果您已经完成此操作但仍然收到异常,请放置堆栈跟踪。
关于java - EasyMock 3 具有类 :,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9500752/
我想更好地理解 EasyMock,并使用它我想出了这个问题。 我想做的是对一个对象设置一个负期望,以检查在测试期间是否没有调用某个方法(在验证那些初始期望时)。 我知道 verify 的默认行为是检查
有没有一种简单的方法来模拟这个调用: objectA.getB().getC(); 现在我这样做的方式是: A mockA = EasyMock.createMock(A.class); B mock
我试图模拟对 final方法的调用 ResourceBundle.getString() .使用 PowerMock 1.4.12 和 EasyMock 3.1,调用不会被模拟;而是调用“真实”方法。
我正在使用 EasyMock 和 EasyMock CE 3.0 来模拟依赖层并测试我的类。以下是我无法找到任何解决方案的场景 我有一个要测试的类,它调用一个依赖类void 方法,该方法接受输入参数,
我有一个间接使用类 Foo 的测试用例。为了测试用例的目的,我不在乎 Foo 是什么。我应该能够 mock 它。 Foo mock = EasyMock.createMock(Foo.class);
我已经使用 EasyMock 编写了很多 Mock 对象。然而,我经常发现编写部分模拟非常耗时,而且感觉不“正确”。 我会说这是一个设计错误,因为我尝试模拟的类将多个关注点合二为一,因此我应该创建单独
在我的单元测试中,我使用 EasyMock 创建模拟对象。在我的测试代码中我有这样的东西 EasyMock.expect(mockObject.someMethod(anyObject())).and
所以我已经使用 EasyMock 的类扩展有一段时间了。突然间,我遇到了这个异常,但只有当我运行整个测试套件时: java.lang.IllegalStateException: 0 matchers
这有什么区别: ResultSet set = EasyMock.createNiceMock(ResultSet.class); EasyMock.expect(set.getInt("col1")
我正在尝试完成有关 easymock 的教程以首次使用它。 http://www.vogella.de/articles/EasyMock/article.html 我正在使用- 面向 Java 开发
我正在使用 TestNG、EasyMock 和 PowerMock 进行测试。根据下面的代码,我尝试模拟从被测静态方法(fetchAuthenticator)调用的静态方法。当我运行测试时,execu
我被分配了将我们的模拟代码从 EasyMock 1-style 升级到 EasyMock 2/3-style 的任务(现在是时候了,因为 EasyMock 1 的大部分内容已于 2005 年被弃用并于
在 API 文档中提到在 strictmock 中默认启用顺序检查,而在 nice mock 的情况下它不是。我不明白他们所说的“订单检查”到底是什么意思。 最佳答案 如果您告诉 mock 期望调用
根据标题,只是想知道是否有一种带有 easymock 的机制来测试方法在其生命周期内是否未被调用。 最佳答案 我知道这个问题很老,但我和 OP 有同样的问题,并做了更多的环顾四周。我找到了以下解决方案
我正在尝试在带有 EasyMock 的 JUnit 中设置测试,但遇到了一个我似乎无法解决的小问题。我希望这里有人可以提供帮助。 这是我尝试测试的方法的简化版本: public void myMeth
这是我第一次使用 EasyMock,我正在尝试向一些遗留代码添加一些单元测试。 遗留代码位于 Spring 3.1 中,我使用的是 EasyMock 3.4。 我在这里想要完成的是测试调用 dao 的
是否可以为循环调用的模拟设置不同的期望? 考虑到用例, while(condition){ List list = Database call //Call to be mocked ..
我正在使用 EasyMock 尝试通过两层深度的项目列表来模拟迭代。我的单元测试代码如下 EventContext ctx = EasyMock.createMock(EventContext
我在使用 EasyMock 时遇到一些奇怪的行为。我已经设置了一些期望,但是当我运行测试时,EasyMock 失败了,因为我的期望按指定执行。以下是失败的示例: Unexpected method c
例如,我创建一个对象,并想为其设置一个属性。问题是,该属性永远不会被设置,因为 EasyMock 会拦截它。如何解决这个问题? ctx = control.createMock(EGContext.c
我是一名优秀的程序员,十分优秀!