微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何为在数据库中保存记录的 void 方法编写 JUnit 5 测试?

如何解决如何为在数据库中保存记录的 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);
    }
}

TodoServiceImpltest.java

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 举报,一经查实,本站将立刻删除。