好的,对不起,我几个小时都在寻找答案,但是我为StackOverflow输入了整个问题来冒泡我正在寻找的链接.你可以阅读很多相关的信息here.
我有一个用Spring Roo创建的Spring项目来使用Hibernate和MysqL.但是,为了进行测试,我想在内存中使用HsqlDB,因为Roo集成测试使用ID(主键)0到10删除数据(而不是使用数据库为他们已创建的数据分配的数据删除数据),这意味着它删除已存在于数据库中的数据,在我的情况下会导致约束违规,然后才能回滚事务.
这有点困难,因为我正在切换整个数据库提供程序,这意味着不同的Hibernate方言以及不同的DDL设置(在生产中验证,在测试中创建 – 丢弃).但它并没有像我期望的那样工作,我为什么难以理解.
如果您知道它为什么不起作用,请说明,即使您没有解决方案.
这是一个Roo项目,我当然正在使用Maven.所以我尝试的第一件事就是拥有一个特定于测试的src / test / resources / meta-inf / persistence.xml文件,同样也是一个特定于测试的src / test / resources / meta-inf / spring / database.propertIEs文件.这没有用,因为当我运行mvn测试时,一切都坏了,相关信息正在进行中
Conflicting persistence unit deFinitions for name 'persistenceUnit'
为什么mvn测试仍然占用非测试资源?
然后我将src / test / resources / meta-inf / spring重命名为spring-test并将applicationContext.xml复制到其中.我将测试类中的上下文配置更改为
@ContextConfiguration(locations =“classpath:/meta-inf/spring-test/applicationContext*.xml”)
完成(或者我认为)分离,我对spring-test / applicationContext.xml进行了一些编辑:
更改了属性文件的路径:
至
更改了持久性单元的名称:
至
我在持久性单元名称中对src / test / resources / meta-inf / persistence.xml进行了相应的更改
好吧,好吧,现在没有冲突,但Hibernate以某种方式失去了实体映射(例如对于Product实体),我得到:
org.springframework.dao.InvalIDDataAccessAPIUsageException:org.hibernate.hql.ast.querySyntaxException: Product is not mapped [SELECT o FROM Product o];
为什么Spring / Hibernate在此配置中丢失了实体映射?
所以接下来我尝试合并两个persistence.xml文件,以便src / main / resources / meta-inf下的一个文件包含两个持久性单元.
这样可行!!??
我认为这很丑陋,因为现在我的生产代码中有测试配置,但这就是我所接受的.
什么是更好的方法?
据我所知,persistence.xml中的属性不像它们在Spring XML文件中那样可用.所以我认为只用一个特定于测试的属性文件就可以做我想做的事情.
理想情况下,我使用src / main / resources下的所有配置运行测试,除了在src / test / resources中专门覆盖的内容.有没有办法实现这个目标?
感谢您提供的任何见解!
最佳答案在我的工作中,我曾经在没有数据库连接信息的情况下配置persistence.xml.数据库连接由Spring的上下文配置定义.在Spring框架中,有几种方法可以更改对象的属性:> PropertyPlaceholderConfigurer – 使用不同的属性文件覆盖ORM的数据库连接或方言的值.如果使用的是Maven,则可以使用resource filter生成单个属性文件的不同值
> Bean definition inheritance – 使用另一个上下文配置“覆盖”默认配置.
以下代码摘自我的应用程序上下文:
以下是测试配置:
Spring security i18n =如何让它一起工作?
上一篇
2022-06-07
Java–jar文件的Spring属性文件配置
下一篇
2022-06-07
评论列表(0条)