DBUnit 更改在事务 Spring 测试中不可见

DBUnit changes not visible inside transactional Spring test

我尝试在 Spring 事务测试中用 DBUnit 填充数据库 Table。 数据源是 TransactionAwareDataSourceProxy。所以我会把这个源给 DBUnit,而不是填充 Table 之后的 jdbcTemplate 查询应该可见吗?

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"many contexts"})
@TransactionConfiguration(transactionManager = "transactionManager")
@Transactional
public class DBTest {

    @Autowired(required = true)
    TransactionAwareDataSourceProxy dataSource;

    private JdbcTemplate jdbcTemplate;

    @Autowired(required = true)
    public void setJdbcTemplate(TransactionAwareDataSourceProxy dataSource) {
        this.jdbcTemplate = new JdbcTemplate(dataSource);
    }

    @Autowired(required = true)
    SessionFactory sessionFactory;

    @Test
    @Transactional
    public void test() throws Exception {
        IDatabaseConnection dbConn = new DatabaseDataSourceConnection(dataSource);
        DatabaseOperation.CLEAN_INSERT.execute(dbConn, new XmlDataSet(ClassLoader.getSystemResourceAsStream("TABLE.xml")));

        System.out.println("Es wurden gefunden : " + this.jdbcTemplate.queryForInt("select count(*) from TABLE"));
        System.out.println("blaaa");

    }

查询总是returns0。 我错过了什么?

当 dbUnit 和生产应用程序共享同一个 transaction/datasource 时,我已经看到这种情况发生了。 "fixes" 它是什么 "flush",通过在测试中手动调用刷新或使用单独的事务或数据库连接(因此 dbUnit 的更改刷新)。

一种解决方案.... 我将 DBUnit 版本从 2.4.9 更改为 2.5.2 现在一切正常。