Что поставить в JTA-Data-Source of Sististence.xml?
Вопрос
Какую ценность я должен поместить в <jta-data-source>
мой persistence.xml
?
В панели администратора GlassFish я создал имя данных DataSource "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, но ...
Я пытаюсь создать EMF в моем моделей тесте:
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 и не использует преимущества встроенного контейнера EJB. Вы можете получить контейнер управляемый EntityManager
В вашем тестовом случае очень легко.
Как и в связи с соответствующими вопросами JNDI / DataSource, я рекомендую вам проверить примеры в примеры .zip.. Отказ Все они предназначены для того, чтобы принять борьбу с начала.
Вот фрагмент от testcase-injection
Пример, который показывает, как вы можете получить EntityManager и другие вещи из контейнера для использования в тесте.
Во-первых, добавьте пустую EJB-Jar.xml или Application-Client.xml в свой тест, чтобы включить сканирование для вашего тестового кода:
- SRC / Test / Resources / Meta-Inf / Application-Client.xml
Затем, аннотируйте свой тест с @org.apache.openejb.api.LocalClient
и использовать стандартные аннотации Javaee для фактической инъекции.
@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 автоматически назначит, что DataSource на ваш блок настойчивости без необходимости модифицировать свою персистентность .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();
}
}