0

我正在使用 HSQLDB 进行单元测试,我有一堆测试类,它们都扩展了一个抽象类 MyAbstractTestBase。

class abstract MyAbstractTestBase 
{
   static
   {
      setUpDBTables();
   }

   public static void setUpDBTables()
   {
        context = new ClassPathXmlApplicationContext(new String[]{
            "file:spring-configuration/unit-testing-config.xml"
        });
        //InputStream inputStream = getClass().getClassLoader().getResourceAsStream("db/MY_TABLE.sql");
        DataSource dataSource = (DataSource)context.getBean("MyDataSource");

        namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(dataSource);

   }
}

这种方法的主要问题是spring创建的entityManager,

@PersistenceContext(unitName = MyConstants.ENTITY_MANAGER_FACTORY_UNIT_NAME)
protected EntityManager entityManager;

不会持久化数据,也不会引发异常,但是如果我尝试使用“选择”读取一些数据,它就可以工作。

这是我的问题,如何在开始单元测试之前创建表?这样我的 entityManager 将按预期工作。

另外,为什么我的 entityManager 没有保留任何记录,即使它没有抛出任何异常。

4

1 回答 1

1

如果您正在使用弹簧测试,我强烈建议您使用此答案中的方法:How to load DBUnit test data once per case with Spring Test

于 2013-06-30T00:41:44.760 回答