繁体   English   中英

当应用程序失败时,Spring MVC测试通过

[英]Spring MVC test passing when application is failing

试图从第四版开始教自己。 在行动中。 我正在使用本书示例作为指南来构建一个Web应用程序,并通过第5章进行工作。我有两个控制器和两个使用Spring MVC的相应测试。 两个测试都通过了,但是当我在服务器(Tomcat 7.0)上运行该应用程序时,它基于ClinicalNoteRepository接口给出了UnsatisfiedDependencyException。 当应用程序找不到ClinicalNoteRepository时,为什么这些测试-特别是ClinicalNoteControllerTest-通过?

以下是Console输出的摘录(字符限制不会让我发布整个内容):

2015年1月12日,上午5:30:23 org.apache.tomcat.util.digester.SetPropertiesRule开始警告:[SetPropertiesRule] {服务器/服务/引擎/主机/上下文}将属性“源”设置为“ org.eclipse.jst” .jee.server:练习健康”未找到匹配的属性。 2015年1月12日5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:服务器版本:Apache Tomcat / 7.0.57 2015年1月12日5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:服务器已构建:2014年11月3日UTC 2015年1月12日5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:服务器编号:7.0.57.0 2015年1月12日5:30上午23:00 org.apache.catalina.startup.VersionLoggerListener日志信息:操作系统名称:Windows 7 Jan 12,2015 5:30:23上午org.apache.catalina.startup.VersionLoggerListener日志信息:操作系统版本:6.1 2015年1月12日上午5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:体系结构:amd64 2015年1月12日上午5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:JAVA_HOME:C:\\ Program Files \\ Java \\ jdk1.7.0_71 \\ jre 2015年1月12日5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:JVM版本:1.7.0_71-b14 2015年1月12日5:30:23 org .apache.catalina.startup.VersionLoggerListener日志信息:JVM供应商:Ora cle Corporation 2015年1月12日,上午5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:CATALINA_BASE:C:\\ Users \\ kyle \\ workspace.metadata.plugins \\ org.eclipse.wst.server.core \\ tmp2 2015年1月12日5:30:23 AM org.apache.catalina.startup.VersionLoggerListener日志信息:CATALINA_HOME:C:\\ Apache-Tomcat \\ apache-tomcat-7.0.57 2015年1月12日5:30:23 AM组织。 apache.catalina.startup.VersionLoggerListener日志信息:命令行参数:-Dcatalina.base = C:\\ Users \\ kyle \\ workspace.metadata.plugins \\ org.eclipse.wst.server.core \\ tmp2 2015年1月12日5:30 :23:00 org.apache.catalina.startup.VersionLoggerListener日志信息:命令行参数:-Dcatalina.home = C:\\ Apache-Tomcat \\ apache-tomcat-7.0.57 Jan 12,2015 5:30:23 AM org。 apache.catalina.startup.VersionLoggerListener日志信息:命令行参数:-Dwtp.deploy = C:\\ Users \\ kyle \\ workspace.metadata.plugins \\ org.eclipse.wst.server.core \\ tmp2 \\ wtpwebapps 2015年1月12日5上午30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:命令行参数:-Dja va.endorsed.dirs = C:\\ Apache-Tomcat \\ apache-tomcat-7.0.57 \\ endorsed 2015年1月12日5:30:23 org.apache.catalina.startup.VersionLoggerListener日志信息:命令行参数:-Dfile .encoding = Cp1252 2015年1月12日,上午5:30:23 org.apache.catalina.core.AprLifecycleListener lifecycleEvent信息:在java.library.path上找不到基于APR的Apache Tomcat本机库,该库允许在生产环境中实现最佳性能。 :C:\\ Program Files \\ Java \\ jdk1.7.0_71 \\ bin; C:\\ Windows \\ Sun \\ Java \\ bin; C:\\ Windows \\ system32; C:\\ Windows; C:\\ ProgramData \\ Oracle \\ Java \\ javapath; C:\\ Program Files(x86)\\ HP SimplePass 2011 \\ x64; C:\\ Program Files(x86)\\ HP SimplePass 2011 \\ ;; C:\\ Program Files \\ Broadcom \\ Broadcom 802.11 \\ Driver ;; C:\\ Program Files \\通用文件\\ Microsoft Shared \\ Windows Live; C:\\ Program Files(x86)\\ Common Files \\ Microsoft Shared \\ Windows Live; C:\\ Windows \\ system32; C:\\ Windows; C:\\ Windows \\ System32 \\ Wbem; C: \\ Windows \\ System32 \\ WindowsPowerShell \\ v1.0 \\; C:\\ Program Files(x86)\\ Common Files \\ Roxio Shared \\ DLLShared \\; C:\\ Program Files (x86)\\ Common Files \\ Roxio Shared \\ DLLShared \\; C:\\ Program Files(x86)\\ Common Files \\ Roxio Shared \\ 12.0 \\ DLLShared \\; C:\\ Program Files(x86)\\ Windows Live \\ Shared; C:\\程序文件\\ WIDCOMM \\蓝牙软件\\; C:\\ Program Files \\ WIDCOMM \\ Bluetooth Software \\ syswow64; C:\\ Program Files \\ Broadcom \\ WHL \\; C:\\ Program Files \\ Broadcom \\ WHL \\ syswow64; C:\\ Program Files \\\\ Broadcom \\ WHL \\ SysWow64 \\; C:\\ Program Files \\ Broadcom \\ WHL \\ SysWow64 \\ syswow64; C:\\ Program Files(x86)\\ Intel \\ Services \\ IPT \\; C:\\ Program Files \\ Java \\ jdk1.8.0_25 \\ bin; C:\\ Program Files \\ Gradle \\ Gradle-2.0 \\ gradle-2.2.1 \\ bin;。 2015年1月12日5:30:23 org.apache.coyote.AbstractProtocol初始化信息:初始化ProtocolHandler [“ http-bio-8080”] 2015年1月12日5:30:23 org.apache.coyote.AbstractProtocol初始化信息:正在初始化ProtocolHandler [“ ajp-bio-8009”] 2015年1月12日,上午org.apache.catalina.startup.Catalina负载信息:初始化在992毫秒中进行了处理2015年1月12日,上午5:30:23单位.apache.catalina.core.StandardService startInternal INFO:启动服务Catalina 2015年1月12日上午5:30:23 org.apache.catalina.core.StandardEngine startInternal INFO:启动Servlet引擎:Apache Tomcat / 7.0.57 2015年1月12日上午5:30:26 org.apache.catalina.core.ApplicationContext日志信息:在类路径上检测到Spring WebApplicationInitializers:[com.kwalker.practicewellness.config.WellnessWebAppInitializer@2b1ecc13] 2015年1月12日org.apache .catalina.core.ApplicationContext日志信息:初始化Spring根WebApplicationContext信息:org.springframework.web.context.ContextLoader-根WebApplicationContext:ini 已开始信息化:org.springframework.web.context.support.AnnotationConfigWebApplicationContext-刷新根WebApplicationContext:启动日期[2015年1月12日星期一1月12日]; 上下文层次结构的根INFO:org.springframework.web.context.support.AnnotationConfigWebApplicationContext-注册带注释的类:[class com.kwalker.practicewellness.config.RootConfig] INFO:org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor-JSR- 330'javax.inject.Inject'注释已找到并支持自动装配WARN:org.springframework.web.context.support.AnnotationConfigWebApplicationContext-上下文初始化期间遇到的异常-取消刷新尝试org.springframework.beans.factory.UnsatisfiedDependencyException:创建bean时出错在文件[C:\\ Users \\ kyle \\ workspace.metadata.plugins \\ org.eclipse.wst.server.core \\ tmp2 \\ wtpwebapps \\ Practice Wellness \\ WEB-INF \\ classes \\ com \\ kwalker \\ practicewellness中定义的名称“ clinicalNoteController” \\ web \\ ClinicalNoteController.class]:通过索引为0的[com.kwalker.practicewellness.data.ClinicalNoteRepository]类型的构造函数参数表示的不满意依赖性: 找不到依赖项类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean:期望至少有1个符合此依赖项自动候选条件的bean。 依赖注释:{}; 嵌套的异常是org.springframework.beans.factory.NoSuchBeanDefinitionException:没有发现类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean作为依赖项:至少应有1个符合此依赖项自动候选条件的bean。 依赖项注释:{} ...继续...原因:org.springframework.beans.factory.NoSuchBeanDefinitionException:没有发现类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean:期望至少1个Bean有资格作为此依赖项的自动装配候选者。 依赖项注释:{} ...继续... ...还有24个错误:org.springframework.web.context.ContextLoader-上下文初始化失败org.springframework.beans.factory.UnsatisfiedDependencyException:创建名称为'clinicalNoteController'的bean时出错定义在文件[C:\\ Users \\ kyle \\ workspace.metadata.plugins \\ org.eclipse.wst.server.core \\ tmp2 \\ wtpwebapps \\ Practice Wellness \\ WEB-INF \\ classes \\ com \\ kwalker \\ practicewellness \\ web \\ ClinicalNoteController中。类]:通过构造函数参数[com.kwalker.practicewellness.data.ClinicalNoteRepository]的索引0表示的不满意依赖关系::未找到依赖项的[com.kwalker.practicewellness.data.ClinicalNoteRepository]类型的合格Bean:至少期望1个符合此依赖项条件的自动装配候选bean。 依赖注释:{}; 嵌套的异常是org.springframework.beans.factory.NoSuchBeanDefinitionException:没有发现类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean作为依赖项:至少应有1个符合此依赖项自动候选条件的bean。 依赖项注释:{}在org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:749)在org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:185)在org。 springorgwork.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1131)在org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1034)在org.springframework.beans.factory.support org.springframework.beans.factory.support.AbstractBeanFactory $ 1.getObject(AbstractBean)。 :303),位于org.springframework.beans.factory.support.DefaultSingletonBeanRegist org.springframework.beans.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java :)上的ry.getSingleton(DefaultSingletonBeanRegistry.java:230) 194)位于org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:762)位于org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:757)位于org.springframework.context.support org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:306)上的org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:403)上的。位于org.apache.catalina.core.Standard的org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:106) org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5492)的org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)的Context.listenerStart(StandardContext.java:4992) org.apache.catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1565)的.apache.catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1575)在java.util.concurrent.FutureTask.run (FutureTask.java:262)在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)在java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:615)在java.lang.Thread。 run(Thread.java:745)由以下原因引起:org.springframework.beans.factory.NoSuchBeanDefinitionException:未找到类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean作为依赖项:至少应有1个符合自动装配条件的Bean此依赖项的候选者。 依赖项注释:{}位于org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1054)的org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoSuchBeanDefinitionException(DefaultListableBeanFactory.java:1308)。 org.springframework.beans.factory.support上的springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:949)在org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:813)上。 ConstructorResolver.createArgumentArray(ConstructorResolver.java:741)... 24年1月12日上午org.apache.catalina.core.StandardContext listenerStart严重:异常将上下文初始化事件发送到org.springframework类的侦听器实例.web.context.ContextLoaderListener org.springframework.beans.factory.UnsatisfiedDependencyException:创建名称为'clinicalNote的bean时出错 在文件[C:\\ Users \\ kyle \\ workspace.metadata.plugins \\ org.eclipse.wst.server.core \\ tmp2 \\ wtpwebapps \\ Practice Wellness \\ WEB-INF \\ classes \\ com \\ kwalker \\ practicewellness \\ web \\中定义的控制器ClinicalNoteController.class]:通过索引为0的[com.kwalker.practicewellness.data.ClinicalNoteRepository]类型的构造函数参数表示的不满意依赖性::未找到依赖项的[com.kwalker.practicewellness.data.ClinicalNoteRepository]类型的合格bean:预期至少1个符合此依赖项条件的bean。 依赖注释:{}; 嵌套的异常是org.springframework.beans.factory.NoSuchBeanDefinitionException:没有发现类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean作为依赖项:至少应有1个符合此依赖项自动候选条件的bean。 依赖项注释:{}在org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:749)在org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:185)在org。 springorgwork.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1131)在org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1034)在org.springframework.beans.factory.support org.springframework.beans.factory.support.AbstractBeanFactory $ 1.getObject(AbstractBean)。 :303),位于org.springframework.beans.factory.support.DefaultSingletonBeanRegist org.springframework.beans.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java :)上的ry.getSingleton(DefaultSingletonBeanRegistry.java:230) 194)位于org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:762)位于org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:757)位于org.springframework.context.support org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:306)上的org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:403)上的。位于org.apache.catalina.core.Standard的org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:106) org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5492)的org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)的Context.listenerStart(StandardContext.java:4992) org.apache.catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1565)的.apache.catalina.core.ContainerBase $ StartChild.call(ContainerBase.java:1575)在java.util.concurrent.FutureTask.run (FutureTask.java:262)在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)在java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:615)在java.lang.Thread。 run(Thread.java:745)由以下原因引起:org.springframework.beans.factory.NoSuchBeanDefinitionException:未找到类型为[com.kwalker.practicewellness.data.ClinicalNoteRepository]的合格Bean作为依赖项:至少应有1个符合自动装配条件的Bean此依赖项的候选者。 依赖项注释:{}在org.springframework.beans.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1054)的org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1054)的org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoSuchBeanDefinitionExcepti on上。 org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:949)在org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:813)在org.springframework.beans.factory.support .ConstructorResolver.createArgumentArray(ConstructorResolver.java:741)...更多2015年1月12日上午5:30:27 org.apache.catalina.core.StandardContext startInternal SEVERE:Error listenerStart 2015年1月12日上午5:30:27 AM org.apache.catalina.core.StandardContext startInternal SEVERE:由于先前的错误,上下文[/ practicewellness]启动失败,原因是2015年1月12日org.apache.catalina.core.ApplicationCon 文本日志INFO:关闭Spring根WebApplicationContext 2015年1月12日,上午org.apache.coyote.AbstractProtocol开始INFO:启动ProtocolHandler [“ http-bio-8080”] 2015年1月12日,上午5:30:27 org .apache.coyote.AbstractProtocol启动信息:正在启动ProtocolHandler [“ ajp-bio-8009”] 2015年1月12日5:30:27 org.apache.catalina.startup.Catalina启动信息:服务器在3494毫秒内启动

ClinicalNoteControllerTest:

package com.kwalker.practicewellness;

import static org.hamcrest.Matchers.hasItems;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.model;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.view;
import static org.springframework.test.web.servlet.setup.MockMvcBuilders.standaloneSetup;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.junit.Test;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.web.servlet.view.InternalResourceView;

import com.kwalker.practicewellness.data.ClinicalNoteRepository;
import com.kwalker.practicewellness.domain.ClinicalNote;
import com.kwalker.practicewellness.web.ClinicalNoteController;

public class ClinicalNoteControllerTest {

@Test
public void shouldShowRecentClinicalNotes() throws Exception {
    List<ClinicalNote> expectedClinicalNotes = createClinicalNoteList(20);
    ClinicalNoteRepository mockNoteRepository = mock(ClinicalNoteRepository.class);
    when(mockNoteRepository.findClinicalNotes(Long.MAX_VALUE, 20)).thenReturn(expectedClinicalNotes);

    ClinicalNoteController noteController = new ClinicalNoteController(mockNoteRepository);
    MockMvc mockMvc = standaloneSetup(noteController).setSingleView(
            new InternalResourceView("/WEB-INF/views/clinicalNotes.jsp")).build();

    mockMvc.perform(get("/clinical-notes"))
        .andExpect(view().name("clinical-notes"))
        .andExpect(model().attributeExists("clinicalNoteList"))
        .andExpect(model().attribute("clinicalNoteList", hasItems(expectedClinicalNotes.toArray())));
}

@Test
public void shouldShowPagedClinicalNotes() throws Exception {
    List<ClinicalNote> expectedClinicalNotes = createClinicalNoteList(50);
    ClinicalNoteRepository mockRepository = mock(ClinicalNoteRepository.class);
    when(mockRepository.findClinicalNotes(238900, 50)).thenReturn(expectedClinicalNotes);

    ClinicalNoteController noteController = new ClinicalNoteController(mockRepository);
    MockMvc mockMvc = standaloneSetup(noteController).setSingleView(
            new InternalResourceView("/WEB-INF/views/clinical-notes.jsp")).build();

    mockMvc.perform(get("/clinical-notes?max=238900&count=50"))
        .andExpect(view().name("clinical-notes"))
        .andExpect(model().attributeExists("clinicalNoteList"))
        .andExpect(model().attribute("clinicalNoteList", hasItems(expectedClinicalNotes.toArray())));
}

private List<ClinicalNote> createClinicalNoteList(int count) {
    List<ClinicalNote> clinicalNotes = new ArrayList<ClinicalNote>();
    for (int i=0; i < count; i++) {
        clinicalNotes.add(new ClinicalNote("Note " + i, new Date()));
    }
    return clinicalNotes;
}

}

ClinicalNoteController类:

package com.kwalker.practicewellness.web;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;

import com.kwalker.practicewellness.data.ClinicalNoteRepository;
import com.kwalker.practicewellness.domain.ClinicalNote;

@Controller
@RequestMapping("/clinical-notes")
public class ClinicalNoteController {

private static final String MAX_LONG_AS_STRING = "9223372036854775807";
private ClinicalNoteRepository noteRepository;

@Autowired
public ClinicalNoteController(ClinicalNoteRepository noteRepository) {
    this.noteRepository = noteRepository;
}

@RequestMapping(method=RequestMethod.GET)
public List<ClinicalNote> clinicalNotes(
        @RequestParam(value="max", defaultValue=MAX_LONG_AS_STRING) long max,
        @RequestParam(value="count", defaultValue="20") int count) {
    return noteRepository.findClinicalNotes(max, count);
}

}

这是ClinicalNoteRepository接口:

package com.kwalker.practicewellness.data;

import java.util.List;

import com.kwalker.practicewellness.domain.ClinicalNote;

public interface ClinicalNoteRepository {
    List<ClinicalNote> findClinicalNotes(long maximumId, int count);
}

POM文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.kwalker</groupId>
<artifactId>practicewellness</artifactId>
<name>Practice Wellness</name>
<packaging>war</packaging>
<version>1.0.0-BUILD-SNAPSHOT</version>

<properties>
    <java-version>1.7</java-version>
    <org.springframework-version>4.1.4.RELEASE</org.springframework-version>
    <org.aspectj-version>1.6.10</org.aspectj-version>
    <org.slf4j-version>1.6.6</org.slf4j-version>

</properties>

<dependencies>
    <!-- Spring -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${org.springframework-version}</version>
        <exclusions>
            <!-- Exclude Commons Logging in favor of SLF4j -->
            <exclusion>
                <groupId>commons-logging</groupId>
                <artifactId>commons-logging</artifactId>
             </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${org.springframework-version}</version>
    </dependency>

    <!-- AspectJ -->
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjrt</artifactId>
        <version>${org.aspectj-version}</version>
    </dependency>   

    <!-- Logging -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>${org.slf4j-version}</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jcl-over-slf4j</artifactId>
        <version>${org.slf4j-version}</version>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>${org.slf4j-version}</version>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.15</version>
        <exclusions>
            <exclusion>
                <groupId>javax.mail</groupId>
                <artifactId>mail</artifactId>
            </exclusion>
            <exclusion>
                <groupId>javax.jms</groupId>
                <artifactId>jms</artifactId>
            </exclusion>
            <exclusion>
                <groupId>com.sun.jdmk</groupId>
                <artifactId>jmxtools</artifactId>
            </exclusion>
            <exclusion>
                <groupId>com.sun.jmx</groupId>
                <artifactId>jmxri</artifactId>
            </exclusion>
        </exclusions>
        <scope>runtime</scope>
    </dependency>

    <!-- @Inject -->
    <dependency>
        <groupId>javax.inject</groupId>
        <artifactId>javax.inject</artifactId>
        <version>1</version>
    </dependency>

    <!-- Servlet -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>jsp-api</artifactId>
        <version>2.2</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>1.2</version>
    </dependency>

    <!-- Test -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>4.1.4.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.mockito</groupId>
        <artifactId>mockito-core</artifactId>
        <version>1.10.19</version>
        <exclusions>
            <exclusion>
                <artifactId>hamcrest-core</artifactId>
                <groupId>org.hamcrest</groupId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <exclusions>
            <exclusion>
                <artifactId>hamcrest-core</artifactId>
                <groupId>org.hamcrest</groupId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.hamcrest</groupId>
        <artifactId>hamcrest-all</artifactId>
        <version>1.3</version>
    </dependency>

    <!-- Misc -->
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-lang3</artifactId>
        <version>3.3.2</version>
    </dependency>

</dependencies>
<build>
    <plugins>
        <plugin>
            <artifactId>maven-eclipse-plugin</artifactId>
            <version>2.9</version>
            <configuration>
                <additionalProjectnatures>
                      <projectnature>org.springframework.ide.eclipse.core.springnature</projectnature>
                </additionalProjectnatures>
                <additionalBuildcommands>
                        <buildcommand>org.springframework.ide.eclipse.core.springbuilder</buildcommand>
                </additionalBuildcommands>
                <downloadSources>true</downloadSources>
                <downloadJavadocs>true</downloadJavadocs>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.2</version>
            <configuration>
                <source>1.7</source>
                <target>1.7</target>
                <compilerArgument>-Xlint:all</compilerArgument>
                <showWarnings>true</showWarnings>
                <showDeprecation>true</showDeprecation>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>exec-maven-plugin</artifactId>
            <version>1.3.1</version>
            <configuration>
                <mainClass>org.test.int1.Main</mainClass>
            </configuration>
        </plugin>
    </plugins>
</build>
</project>

从这两行代码可以看出:

ClinicalNoteRepository mockNoteRepository = mock(ClinicalNoteRepository.class);
ClinicalNoteController noteController = new ClinicalNoteController(mockNoteRepository);

...您的测试是单元测试,它们自己创建模拟存储库实例并使用这些模拟对象构造控制器。

在服务器上运行时,Spring配置用于确定框架需要管理哪些bean。 因此,根据您的情况,您的配置可能存在问题。

在您提供的代码中, ClinicalNoteRepository只是一个接口。 必须有一个可用作Spring Bean的接口的实现。 您没有向我们展示这样的实现,所以可能只是您没有编写一个实现。 如果您使用的是Spring Data(提供自己的实现),则此规则例外。 但是,在这种情况下,您的接口将需要扩展JpaRepository或其他Spring Data存储库接口之一。

请注意,您可以编写测试来加载Spring上下文(从而测试您的配置)。 为此,您需要在测试类中添加以下注释:

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = MyAppConfiguration.class)

...假设您正在使用Spring Boot。 或诸如

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = { MyConfiguration.class }, 
                   loader = AnnotationConfigContextLoader.class)

...如果您有一个更传统的Spring应用程序,在这种情况下,您可以将其指向一个或多个Java @Configuration类(如上)或XML配置文件列表。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM