- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有以下类(class):
public class Plugin {
private DistributionManager manager;
public void init(){
ApplicationContext context =
new ClassPathXmlApplicationContext("applicationContext.xml");
manager = context.getBean(DistributionManager.class);
}
public String doSomething(){
String s = manager.doSomething();
return doSomethingElse(s);
}
DistributionManager
类本身有很多 Autowiring 的依赖项并标记为 @Component
现在我想为所有这些代码运行一些单元测试:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"/applicationContext.xml"})
public class PluginTestCase extends AbstractJUnit4SpringContextTests{
@Resource
DistributionManager manager;
@Test
public void testDoSomething(){
Plugin plugin = mock(Plugin.class);
//how can I inject DistributionMamanger bean to plugin using mockito?
assertEquals("MyResult", plugin.doSomething());
}
}
我以前从未使用过 mockito。你能帮我模拟插件并完成这个单元测试吗?
更新:
我正在根据建议尝试以下测试:
@RunWith(MockitoJUnitRunner.class)
public class PluginTestCase {
@Mock
DistributionManager manager;
@InjectMocks
Plugin testedPlugin;
@Before
public void setUp(){
MockitoAnnotations.initMocks(this);
}
@Test
public void testDao(){
testedPlugin.init();
testedPlugin.doSomething();
}
}
但是,我有以下异常:
org.mockito.exceptions.base.MockitoException: Field 'testedPlugin' annotated with @InjectMocks is null.
Please make sure the instance is created *before* MockitoAnnotations.initMocks();
Example of correct usage:
class SomeTest {
@InjectMocks private Foo foo = new Foo();
@Before public void setUp() {
MockitoAnnotations.initMock(this);
at org.mockito.internal.runners.JUnit45AndHigherRunnerImpl$1.withBefores(JUnit45AndHigherRunnerImpl.java:27)
at org.junit.runners.BlockJUnit4ClassRunner.methodBlock(BlockJUnit4ClassRunner.java:261)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:76)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
at org.mockito.internal.runners.JUnit45AndHigherRunnerImpl.run(JUnit45AndHigherRunnerImpl.java:37)
at org.mockito.runners.MockitoJUnitRunner.run(MockitoJUnitRunner.java:62)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:49)
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)
最佳答案
如果 Plugin
是您要进行单元测试的类,请不要模拟它。恰恰相反!同样对于单元测试,我绝对会避免创建 spring 上下文,相反,您应该只为集成测试或一些非常罕见/特定的情况这样做。
无论如何,我想你想测试插件和管理器之间的交互。因此,您绝对应该阅读 Mockito 文档,但这是在插件中注入(inject)模拟管理器的第一个开始。
@RunWith(MockitoJUinitRunner.class)
public class PluginTest {
@Mock DistributionManager mockedManager;
@InjectMocks Plugin testedPlugin = new Plugin(); // initialization not need when using Mockito 1.9.x
@Test public void plugin_should_call_the_the_manager_on_doSomething() {
// given
// when
// then
}
// other scenarios
}
请注意,您只需要使用 JUnit 运行程序 MockitoJUinitRunner.class
或实用程序类和方法 MockitoAnnotations.init()
,但不能同时使用!
其他备注:
@Test
注释,您可以随意命名它们对测试的意图具有可读性和表达性。@Before
和 @After
注释,您可以描述您设置或拆除的内容。PluginTestCase
,后缀 TestCase
仅用于将由后缀为 的实际测试扩展的抽象类>测试
例如MyClassTest
。不管怎样,Maven Surefire 会寻找名为*Test
的类。关于java - 模拟 Spring Bean ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8197921/
有什么区别 和 您能解释一下这两者之间有什么区别吗? 最佳答案 它是一个 XML 命名空间,用于分隔可能存在冲突的元素名称,因此没有真正的区别。 XML Namespaces 关于java -
我刚刚浏览了两个 Web 应用程序,在两个项目的“applicationContext.xml”文件中都有一个标记 ... 另一个是 ... 谁能给我解释一下有什么区别吗? 最佳答案 没有语
我一直在尝试了解 WebSphere Commerce 中的 Java bean,但我真的很困惑。请帮帮我。我需要知道: What is the difference between EntityBe
自从我们更新到 grails 2.0.1(从 2.0.0 开始)以来,通过 bean 字段显示的所有 bean 都错误地显示为“withBean”字段的第一个属性。在我下面发布的示例中,所有 [fir
我有一个 bean,我将另一个 beanlist 放入其中,并且我想访问该内部 bean。 我的第一个 Bean 是: public class FirstDTO { private String F
我正在尝试将 CSS 和 JS 添加到 spring MVC 项目中的 JSP 页面,以便我在 dispatcher-servlet.xml 中包含了 js/css 文件夹的引用,如下所示:
当我将请求传递给 RestController 时,出现以下错误。 org.springframework.beans.factory.xml.XmlBeanDefinitionStoreExcept
我看到很多示例将 bean 标记为实体 bean (@Entity) 和命名 bean (CDI),以避免创建 2 个类(托管 bean 和实体 bean)并利用 Bean 验证以便可以执行验证在客户
在我的理解中, session 总是意味着有状态。考虑 servlet session 对象, 想想 cookie。如果 session 是无状态的,我认为我们根本不需要 session 。 在jee
我完全是Spring框架的初学者。我当时正在玩一个创建对象实例的示例。因此需要您的帮助! 看看这个例子: MainApp.java: import org.springframework.contex
这个问题在这里已经有了答案: What is a JavaBean exactly? (23 个回答) 关闭 7 年前。 我已经阅读了有关 EJB、Java Beans 的内容,但是我仍然对“bea
我刚开始使用 Spring-Framework,实际上我正在使用 spring-boot 库。我有以下问题: 我知道在 @Configuration 类中使用 @Bean 注册的 bean 默认是单例
我对下面提到的场景中使用Spring Framework时会创建的实例数量有疑问: bean配置是这样的 or 默认情况下,bean "a"有 singleton scope .所以
在我的 Spring-Module.xml 中,我有两个 bean: ... ... 我像这样实例化我的类: Applicat
@Autowired private Map departments; 我的 spring 配置文件 只要使用 @Autowired 需要日期,它就可以正常工作 同样, 如何使用没有属性
我已经为 ComboBox 设置了 ContainerDataSource this.comboBox.setContainerDataSource(container)。这个容器是一个 BeanIt
为了支持流畅的编程风格,我最近修改了我们的 Java Beans setter 方法以返回 Bean 类。但是现在 Java Beans Activation Framework (rel 1.1)
有人可以告诉我在我的 ApplicationContext 中我必须使用 beans:bean 而不是 bean 的什么以及如何修复它。
我有如下配置: batch:job id="reconciliationJob" job-repository="jobRepository" restartable="true" 在应用程序上下文启
我已经为 Test_flow 创建了简单的测试套件,但是当我尝试运行该流程时出现错误。 java.lang.RuntimeException: org.mule.api.config.Configur
我是一名优秀的程序员,十分优秀!