首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ModelAndView返回空SpringBootTest

ModelAndView返回空SpringBootTest
EN

Stack Overflow用户
提问于 2018-10-04 11:41:53
回答 1查看 1.1K关注 0票数 0

我正在尝试使用spring引导来学习junit测试。通常,我不会只问空指针异常,但现在我找不到丢失的东西。

代码语言:javascript
复制
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = WebEnvironment.MOCK)
@ActiveProfiles("dev")
@AutoConfigureMockMvc
@WithMockUser(username = "user", password = "secret", authorities = "USER")
public class OwnersWebMVCTests {

    @Autowired
    private MockMvc mockMvc;

    @Test
    public void testOwners() throws Exception {
        MockHttpServletRequestBuilder requestBuilder = MockMvcRequestBuilders.get("/owners");
        ResultActions resultActions = mockMvc.perform(requestBuilder);

        MvcResult mvcResult = resultActions.andReturn();

        ModelAndView mav = mvcResult.getModelAndView();

        MatcherAssert.assertThat(mav.getViewName(), Matchers.equalTo("owners"));
        MatcherAssert.assertThat(mav.getModel().containsKey("owners"), Matchers.is(true));

    }
}

ModelAndView mav =mvcResult.getModelAndView();返回null。

这是我的错误堆栈。

代码语言:javascript
复制
{
java.lang.NullPointerException
    at demo.petClinic.web.OwnersWebMVCTests.testOwners(OwnersWebMVCTests.java:40)
    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:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.springframework.test.context.junit4.statements.RunBeforeTestExecutionCallbacks.evaluate(RunBeforeTestExecutionCallbacks.java:73)
    at org.springframework.test.context.junit4.statements.RunAfterTestExecutionCallbacks.evaluate(RunAfterTestExecutionCallbacks.java:83)
    at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:251)
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:97)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:190)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:538)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:760)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:460)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:206)
}

什么都能帮上忙谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-04 12:54:42

问题与控制器有关,而不是与测试有关。

可能出现的问题:您的控制器没有被扫描!我这么说是因为您希望拥有相同的GET url并查看“所有者”=>,这将失败,因为它将重定向到自身。

解决方案:请确保控制器和弹簧引导测试具有相同的包名,或者导入一个配置来扫描它。

src/main/java/org.test OwnerController ->

src/test/java/org.test TestOwnerController ->

相同的包名:org.test

如果需要使用不同的包名,可以将其添加到测试中。

代码语言:javascript
复制
@ComponentScan("org.owner") 

->,其中org.owner是OwnerController的包

改进:您可以将测试方法重写为

代码语言:javascript
复制
mockMvc.perform(get("/owners"))
       .andExpect(model().attributeExists("owners"))
       .andExpect(view().name("view"));

还请将返回视图的名称更改为“不失败”:

代码语言:javascript
复制
@GetMapping(value = "/owners")
public ModelAndView getOwnersView() {
    return new ModelAndView("view", Collections.singletonMap("owners", new Object()));
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52645806

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档