如何解决如何为在数据库中保存记录的 void 方法编写 JUnit 5 测试?
我在 Spring Boot 中有一个简单的待办事项应用程序。我正在尝试为 createtodo
方法编写一个测试,该方法将待办事项保存在存储库/数据库中。我在 java.lang.NullPointerException
todoServiceImpl.createtodo(newTodo);
我错过了什么?是否可以在不模拟存储库的情况下对其进行测试?
TodoServiceImpl.java
类
@AllArgsConstructor
@Slf4j
@Service
public class TodoServiceImpl implements TodoService {
private final TodoRepository todoRepository;
@Override
public void createtodo(Todo todo) {
todoRepository.save(todo);
}
}
class TodoServiceImpltest {
@Mock
private TodoRepository todoRepository;
private Todo todo;
private TodoServiceImpl todoServiceImpl;
@BeforeEach
public void setup(){
todoServiceImpl = new TodoServiceImpl(todoRepository);
}
@Test
@displayName("New todo should be saved")
void createtodotest() {
// Setup
Todo newTodo = Todo.builder().id("1").todo("Shopping").build();
todoServiceImpl.createtodo(newTodo);
// Expected behavior
Optional<Todo> todo = todoRepository.findById("1");
// Assert
assertEquals(todo.getTodo(),"Shopping");
assertTrue(todo.isPresent());
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。