Lo que hay que poner en JTA-datos-fuente de persistence.xml?
Pregunta
¿Qué valor debería colocar en <jta-data-source>
de mi persistence.xml
?
En el panel de administración glassfish he creado un nombre de fuente de datos "abcDS"
. En mi jndi.properties
(dentro src/test/resources
) he definido como esto:
[...]
abcDS=new://Resource?type=DataSource
abcDS.JdbcDriver=org.hsqldb.jdbcDriver
abcDS.JdbcUrl=jdbc:hsqldb:mem:testdb
abcDS.JtaManaged=true
[...]
¿Qué voy a colocar en persistence.xml
? He encontrado una gran cantidad de variantes en la red, como: "jdbc/abcDS"
, "java:/abcDS"
, "abcDS"
. ¿Cuál es la correcta? ¿Y hay alguna regla para esto? Yo entiendo que se relaciona con JNDI, pero ...
Estoy intentando crear EMF en mi unidad de prueba:
EntityManagerFactory emf = Persistence.createEntityManagerFactory("abc");
Esto es lo que estoy haciendo en el registro:
[...]
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)
[...]
Solución
El problema es que Persistence.createEntityManagerFactory("abc")
es el "hágalo usted mismo" API y no toma ventaja de la Embedded contenedor EJB. Usted puede obtener una EntityManager
logrado recipiente en el caso de test con mucha facilidad.
Al igual que con la jndi relacionados / fuente de datos pregunta le recomiendo que echa un vistazo a los ejemplos en el examples.zip . Todos ellos están diseñados para llevar la lucha de ponerse en marcha.
He aquí un fragmento del ejemplo testcase-injection
que muestra cómo se puede obtener un EntityManager y otras cosas del recipiente para su uso en una prueba.
En primer lugar, añadir un EJB-jar.xml vacío o aplicación client.xml a su prueba para activar el escaneo de su código de prueba:
- src / test / resources / META-INF / aplicación client.xml
A continuación, anotar el caso de test con @org.apache.openejb.api.LocalClient
y utilizar las anotaciones JavaEE estándar para la inyección real.
@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);
}
Como movieDatabase
es la única fuente de datos que hemos configuración, OpenEJB asignará automáticamente que DataSource a su unidad de persistencia sin la necesidad de modificar su persistence.xml. Usted puede incluso dejar el <jta-data-source>
o <non-jta-data-source>
vacía y OpenEJB todavía sabrá qué hacer.
Sin embargo, en aras de la exhaustividad, aquí es cómo esta aplicación particular ha definido el 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>
A continuación, la parte divertida, utilizando todo junto en pruebas
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();
}
}