本文介紹了測試Hibernate@Check約束時無法生成約束沖突異常的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我正在使用Hibernate@Check
批注,但不能讓我的測試在不滿足約束時失敗。當前僅對H2數據庫使用默認的Spring啟動配置。
我錯過了什么?save(..)
之后是否應該有某種刷新?
運行測試時,我看到正確創建了表。如果我從日志中復制創建行,并使用它在我的”真正的”postgres數據庫中創建表,我可以測試不同的插入,并看到此行完全可以使用約束。
實體
@Getter @Setter
@Entity @Check(constraints = "a IS NOT NULL OR b IS NOT NULL")
public class Constrained {
@Id @GeneratedValue
private Long id;
private String a, b;
}
測試
@DataJpaTest
@RunWith(SpringRunner.class)
public class HibernateCheckTest {
@Resource // this repo is just some boiler plate code but attached at
// the bottom of question
private ConstrainedRepository repo;
@Test @Transactional // also tried without @Transactional
public void test() {
Constrained c = new Constrained();
repo.save(c); // Am I wrong to expect some constraint exception here?
}
}
運行測試時的表格生成腳本
CREATE TABLE約束(id bigint非空,a varchar(255),b
Varchar(255),主鍵(Id),檢查(a不為空或b不為空
空))
存儲庫(在repo中查看不多,只是為了顯示它):
public interface ConstrainedRepository
extends CrudRepository<Constrained, Long> {
}
但是
如果我使用EntityManager
將其添加到測試類:
@PersistenceContext
private EntityManager em;
和執行如下持久化操作:
em.persist(c);
em.flush();
我將獲得異常,而不是repo.save(c)
。
和
使用repo.save(c)
更仔細地研究原始測試的日志顯示:
org.springframework.test.context.transaction.TransactionContext:139-已回滾用于測試的事務:
…
測試異常=[空],
因此,出于某種原因,該錯誤只是被包裝和記錄。如何在使用倉庫持久化時進行解包和拋出?
推薦答案
感謝codemonkey中的answer我能夠找到解決方案。這可以通過添加:
來解決
@org.springframework.transaction.annotation.Transactional(propagation =
Propagation.NOT_SUPPORTED)
到我的測試類。
這篇關于測試Hibernate@Check約束時無法生成約束沖突異常的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,