36

のどの値を設定する必要が<jta-data-source>ありpersistence.xmlますか?

Glassfish 管理パネルで、 datasource name を作成しました"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"、ネットで多くの亜種を見つけました。どちらが正しいですか?そして、これには何らかの規則がありますか?JNDI関係なのはわかるけど…"java:/abcDS""abcDS"

単体テストで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)
[...]
4

1 に答える 1

40

問題はPersistence.createEntityManagerFactory("abc")、「自分でやる」API であり、組み込み EJB コンテナを利用していないことです。EntityManagerテスト ケースでコンテナを管理するのは非常に簡単です。

関連する jndi/datasource の質問と同様に、examples.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);
    }

セットアップした唯一の DataSource であるためmovieDatabase、OpenEJB は、persistence.xml を変更する必要なく、その DataSource を永続ユニットに自動的に割り当てます。<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();
    }
}
于 2010-10-29T18:24:11.123 に答える