У меня есть однонаправленные связанные объекты:
@Entity
public class Book {
private String isbn;
}
@Entity
private class Recommentation {
@ManyToOne(optional = false, fetch = FetchType.LAZY)
@JoinColumn(name = "book_id", nullable = false)
@OnDelete(action = OnDeleteAction.CASCADE)
private Book book;
}
И следующий тест:
@RunWith(SpringRunner.class)
@DataJpaTest
public class BookRepositoryTest {
@Autowired
private TestEntityManager testEntityManager;
@Autowired
private BookRepository bookRepository;
@Test
public void delete() {
// given
String isbn = "isbn-1";
Book book = new Book();
book.setIsbn(isbn);
testEntityManager.persist(book);
Recommendation recommendation = new Recommendation();
recommendation.setBook(book);
testEntityManager.persist(recommendation);
// when
bookRepository.deleteBookByIsbn(book.getIsbn());
// then
assertThat(testEntityManager.find(Book.class, book.getId())).isNull();
assertThat(testEntityManager.find(Recommendation.class, recommendation.getId())).isNull();
}
}
@OnDelete(action = OnDeleteAction.CASCADE)
отлично работает, когда этот код вызывается не из теста, а втест, я получаю исключение, что рекомендация не удаляется книгой.
Также я пытаюсь получить какую-либо информацию из sql, зарегистрированную для запросов гибернации, и я не вижу никаких операторов delete
для этого теста.
Я не хочу использовать двунаправленное связывание для сущностей и просто пытаюсь понять, как решить эту конкретную проблему или как-то отладить ее.