これは、A が B と 1 対多の関係を持つサンプル テスト ケースです。B のインスタンスを B のリスト A に追加し、A のインスタンスで SaveOrUpdate を実行しますが、ロールバックが true の場合、テスト ケースは失敗します。 B のインスタンスの ID が生成されないため。Rollback が false の場合はパスしますが、データベースにもエントリが追加されます。
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration
@WebAppConfiguration
@TestExecutionListeners({ DependencyInjectionTestExecutionListener.class,
TransactionalTestExecutionListener.class,DbUnitTestExecutionListener.class})
@TransactionConfiguration(transactionManager="transactionManager",defaultRollback=true)
@Transactional(propagation=Propagation.REQUIRED)
public class Test1 {
@Autowired
DummyDao dummyDao;
@Test
// @Rollback(false)
public void newTest2(){
// A temp=dummyDao.getAById(new Long(1));
A temp=dummyDao.getAs().get(0);
Hibernate.initialize(temp.getBs());
B class2=new B();
temp.getBs().add(class2);
dummyDao.saveA(temp);
assertNotNull(class2.getId());
}
}
クラスAの詳細
import java.util.List;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import org.hibernate.annotations.Cascade;
import org.hibernate.annotations.CascadeType;
import org.hibernate.annotations.IndexColumn;
@Table(name="UJJWAL_DUMMY", schema="dbo")
@Entity
public class A {
@Id
@Column
@GeneratedValue(strategy=GenerationType.AUTO)
private Long id;
@Column
private String prop;
@OneToMany(fetch=FetchType.LAZY)
@Cascade({CascadeType.ALL})
@JoinColumn(name="fk_A")
@IndexColumn(name="idx")
private List<B> Bs;
// Setter and getters
}
クラスBの詳細 @Entity public class B {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column
private Long id;
@Column
private String dummyColumn2;
// Setters and Getters
}