【问题标题】:can't find saved entity in test在测试中找不到保存的实体
【发布时间】:2019-06-14 15:49:39
【问题描述】:

我正在测试我的 spring 应用程序,但是有一些连线的东西。我不知道为什么会这样。

在我的 spring 代码中,我使用 crudRepository 将 requestBody 保存到 db 中。我可以使用 crudRepository 找到保存的项目。 但是当我运行 unittest 并使用 TestRestTemplate 调用相同的方法时,我找不到使用 crudRepository 保存的项目。

服务器

@PostMapping("")
    public Question saveQuestion(@RequestBody Question question) {
        questionRepository.save(question);

        for(Question _p:questionRepository.findAll()) {
            Application.LOG.info("[saveQuestion] "+_p.toString());
        }
        // I can find saved Question
        return question;
    }

单元测试

@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
@Transactional
public class QuestionControllerTest {
    @Autowired TestRestTemplate restTemplate;
    @Autowired QuestionRepository questionRepository;
@Test
    public void addNewQuestionTest() throws InterruptedException {
        String json= "{\"uniqueId\":1}";

        HttpEntity<String> req = new HttpEntity<>(json, headers);

        ResponseEntity<Question> response = restTemplate.postForEntity("/question", req, Question.class);

        for(Question _p:questionRepository.findAll()) {
            Application.LOG.info("[addNewQuestion]"+_p.toString());
        }
        // I can't find saved question.
    }
}

日志看起来像这样。

[saveQuestion] Question(0)
[saveQuestion] Question(1)
[addNewQuestionTest] Question(0)

但我除外

[saveQuestion] Question(0)
[saveQuestion] Question(1)
[addNewQuestionTest] Question(0)
[addNewQuestionTest] Question(1)

我检查了 db 是否有数据,并且 saveQuestion 方法打印了 2 个项目。 但 addNewQuestionTest 方法中只有一项。

我错过了什么吗?

【问题讨论】:

    标签: java spring junit spring-data-jpa integration-testing


    【解决方案1】:

    这只是一个假设,但可能会发生如下情况:

    1)您已将整个测试标记为在某个事务下运行:

    @Transactional
    public class QuestionControllerTest {
    

    2)当您点击 post 方法时,它会保存实体但在它自己的/新事务中

    ResponseEntity<Question> response = restTemplate.postForEntity("/question", req, Question.class);
    

    来自 1) 的交易在此处仍处于活动状态,因此您有 2 笔交易。

    3)由于保存已在单独的事务中执行,而第一个事务仍处于活动状态,因此第一个事务尚未访问事务 2) 保存的数据。

    解决方案

    由于 Spring JPA 存储库本质上是事务性的,我将从测试配置中删除 @Transactional

    现在,当您点击questionRepository.findAll() 时,它会触发一个新事务,该事务将有权访问由第一个事务保存的数据,该事务保存问题。

    【讨论】:

    • 天啊。当我删除@Transactional 时,测试通过了。非常感谢。我需要了解更多关于 JPA 和 Transactional 的信息
    猜你喜欢
    • 1970-01-01
    • 2018-06-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-09-22
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多