什么投入jta数据来源persistence.xml?
题
什么样的价值,我应该到的地方 <jta-data-source>
我 persistence.xml
?
在我们的管理面板我创建了一个数据源的名字 "abcDS"
.我 jndi.properties
(内部 src/test/resources
)我定义这样的:
[...]
abcDS=new://Resource?type=DataSource
abcDS.JdbcDriver=org.hsqldb.jdbcDriver
abcDS.JdbcUrl=jdbc:hsqldb:mem:testdb
abcDS.JtaManaged=true
[...]
我应该到的地方 persistence.xml
?我已经发现了很多变量净额,如: "jdbc/abcDS"
, "java:/abcDS"
, "abcDS"
.哪一个是正确的?而且是有一些规则是为了这个?我的理解是,它是有关JNDI,但是...
我试图创造的电磁场在我的单元试验:
EntityManagerFactory emf = Persistence.createEntityManagerFactory("abc");
这是什么我在记录:
[...]
SEVERE: Could not find datasource: abcDS javax.naming.NameNotFoundException:
Name "abcDS" not found.
at org.apache.openejb.core.ivm.naming.IvmContext.federate(IvmContext.java:193)
at org.apache.openejb.core.ivm.naming.IvmContext.lookup(IvmContext.java:150)
at org.apache.openejb.core.ivm.naming.ContextWrapper.lookup(ContextWrapper.java:115)
at javax.naming.InitialContext.lookup(InitialContext.java:392)
[...]
解决方案
问题是, Persistence.createEntityManagerFactory("abc")
是"自己做"API和不利用嵌入式源集.你可以得到一个容器管理 EntityManager
在你的测试的情况下很容易。
正如与相关的jndi/数据源的问题,我建议你查出的实例 examples.zip.他们都设计的斗争的开始。
这里的一段从 testcase-injection
例如,它显示了可以如何获得一。和其他的东西从容器的使用在一个测试。
第一,添加一个空的ejb-jar.xml 或application-client.xml 你的测试打扫描你的测试码:
- src/test/resources/META-INF/application-client.xml
然后,注释你的测试情况 @org.apache.openejb.api.LocalClient
和使用的标准java ee说明实际的注射。
@LocalClient
public class MoviesTest extends TestCase {
@EJB
private Movies movies;
@Resource
private UserTransaction userTransaction;
@PersistenceContext
private EntityManager entityManager;
public void setUp() throws Exception {
Properties p = new Properties();
p.put(Context.INITIAL_CONTEXT_FACTORY, "org.apache.openejb.client.LocalInitialContextFactory");
p.put("movieDatabase", "new://Resource?type=DataSource");
p.put("movieDatabase.JdbcDriver", "org.hsqldb.jdbcDriver");
p.put("movieDatabase.JdbcUrl", "jdbc:hsqldb:mem:moviedb");
InitialContext initialContext = new InitialContext(p);
// Here's the fun part
initialContext.bind("inject", this);
}
作为 movieDatabase
是唯一数据源,我们已经安装,OpenEJB将自动分配的数据源于你的持久性单元中没有需要修改persistence.xml.你甚至可以离开 <jta-data-source>
或 <non-jta-data-source>
空和OpenEJB会仍然知道怎么做。
但为了完整起见,这里就是这个特别的应用程序有定义的 persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">
<persistence-unit name="movie-unit">
<jta-data-source>movieDatabase</jta-data-source>
<non-jta-data-source>movieDatabaseUnmanaged</non-jta-data-source>
<class>org.superbiz.testinjection.Movie</class>
<properties>
<property name="openjpa.jdbc.SynchronizeMappings" value="buildSchema(ForeignKeys=true)"/>
</properties>
</persistence-unit>
</persistence>
然后有趣的一部分,利用它所有的在一起试验
public void test() throws Exception {
userTransaction.begin();
try {
entityManager.persist(new Movie("Quentin Tarantino", "Reservoir Dogs", 1992));
entityManager.persist(new Movie("Joel Coen", "Fargo", 1996));
entityManager.persist(new Movie("Joel Coen", "The Big Lebowski", 1998));
List<Movie> list = movies.getMovies();
assertEquals("List.size()", 3, list.size());
for (Movie movie : list) {
movies.deleteMovie(movie);
}
assertEquals("Movies.getMovies()", 0, movies.getMovies().size());
} finally {
userTransaction.commit();
}
}