2015-12-20 2 views
-1

Я пытаюсь проверить контроллер Spring, который имеет метод getProductById. У меня есть какое-то исключение, которое я не понимаю. Я скопирую трассировку стека. Я все еще участвую, и я не знаю, все ли в порядке.Тест Spring Unit с исключениями исключений Java

@Controller 
    @RequestMapping("books") 
    public class BookController { 

     @Autowired 
     BookService bookService; 
    @RequestMapping("/product") 
     public String getProductById(@RequestParam("id") String productId, Model model) { 
      model.addAttribute("allBooks", bookService.getBookById(productId)); 
      return "book"; 
     } 

    } 

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations = { "/applicationContext.xml" }) 
@WebAppConfiguration 
@RequestMapping("books") 
public class BookControllerTest { 

    @Mock 
    private BookService bookService; 

    @InjectMocks 
    private BookController bookController; 

    private MockMvc mockMvc; 

    @Before 
    public void before() { 
     MockitoAnnotations.initMocks(this); 
     this.mockMvc = MockMvcBuilders.standaloneSetup(bookController).build(); 
    } 
@Test 
    public void testGetProductById() { 
     Book book = new Book("3", "book", "book", 5253); 
     String id = book.getId(); 
     assertNotNull("Object can not have null id ", id); 

     Book searchedBook = bookService.getBookById(id); 
     Assertions.assertThat(searchedBook).isNotNull(); 

     assertTrue("Found book id should be equal to id being searched", searchedBook.getId().compareTo(id) == 3); 
    } 

java.lang.AssertionError: expecting actual value not to be null 
    at org.fest.assertions.Fail.failure(Fail.java:228) 
    at org.fest.assertions.Fail.fail(Fail.java:167) 
    at org.fest.assertions.Fail.failIfActualIsNull(Fail.java:100) 
    at org.fest.assertions.GenericAssert.isNotNull(GenericAssert.java:238) 
    at com.book.controller.test.BookControllerTest.testGetProductById(BookControllerTest.java:61) 
    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.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74) 
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83) 
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:88) 
    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.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) 
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:309) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174) 
    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:459) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192) 

ответ

2
Book searchedBook = bookService.getBookById(id); 
Assertions.assertThat(searchedBook).isNotNull(); 

Вы утверждаете, что вы получите книгу из вашего bookservice, но это не так, как показывает ваше исключение:

java.lang.AssertionError: expecting actual value not to be null

Очевидно, что searchedBook равна нулю. Причина этого проста: почему бы и нет? Ваш bookService - это объект Mock, и вы никогда не говорите, что издевались над чем-то конкретным, поэтому он, вероятно, всегда будет возвращать null.

Другими словами, то, что вы делаете это:

  1. «Эй, создать мне фиктивный объект - объект, который претендует быть bookservice»
  2. «Эй, фиктивный объект, дайте мне книга с идентификатором X "
  3. Mock Object: urm? Какие? Вы никогда не говорили мне, что делать, когда вы спрашиваете меня об этом. Извините, единственное, что я получил здесь: null. Получайте удовольствие от этого.

Проверка поведения макета в любом случае не имеет смысла. Обычно вы говорите макету, чтобы сделать что-то конкретное, чтобы вы могли проверить что-то еще. Тестирование объекта, который претендует на роль другого объекта ... зачем?

В вашем случае вы, вероятно, захотите проверить свой bookController, и для этого вам понадобится макет bookservice, чтобы вести себя определенным образом (потому что реальный книжный сервис, вероятно, зависит от базы данных или чего-то подобного).

Смежные вопросы