2

これが私が実行している Roo スクリプトです。ターミナルと STS の両方で、シェルからバージョン spring-roo-1.2.2.RELEASE を使用します。

persistence setup --provider DATANUCLEUS --database GOOGLE_APP_ENGINE --applicationId roo-gae

entity jpa --class ~.domain.Wheel --testAutomatically
field string --fieldName code --notNull --unique

entity jpa --class ~.domain.Car --testAutomatically
field string --fieldName name --notNull --unique
field string --fieldName color --notNull
field reference --fieldName wheel --type ~.domain.Wheel --notNull

perform tests

プロジェクトに手動で変更を加えていませんが、テストの実行は次のメッセージで失敗します。

[ERROR] Failed to execute goal org.datanucleus:maven-datanucleus-plugin:3.0.2:enhance (default) on project test: Error executing DataNucleus tool org.datanucleus.enhancer.DataNucleusEnhancer: InvocationTargetException: Plugin (Bundle) "org.datanucleus.enhancer" is already registered. Ensure you dont have multiple JAR versions of the same plugin in the classpath. The URL "file:/home/timh/.m2/repository/org/datanucleus/datanucleus-enhancer/3.1.0-m1/datanucleus-enhancer-3.1.0-m1.jar" is already registered, and you are trying to register an identical plugin located at URL "file:/home/timh/.m2/repository/org/datanucleus/datanucleus-enhancer/3.0.1/datanucleus-enhancer-3.0.1.jar." -> [Help 1]
[ERROR] .Car roo> 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] .Car roo> 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException

クラスパスに datanucleus-enhancer-3.0.1.jar がありますが、datanucleus-enhancer-3.1.0-m1.jar がプラグインによってダウンロードされていると思います。この問題の解決策または回避策を知っている人はいますか?

4

2 に答える 2

2

これは、 の依存関係の下に以下を追加して、datanucleus エンハンサー プラグインのバージョンを手動で指定することで修正できmaven-datanucleus-pluginますpom.xml

<dependency>
 <groupId>org.datanucleus</groupId>
 <artifactId>datanucleus-enhancer</artifactId>
 <version>3.1.0-m2</version>
</dependency>

追加すると、最終的な maven-dataanucleus-plugin 構成は以下のようになります。

<plugin>
<groupId>org.datanucleus</groupId>
<artifactId>maven-datanucleus-plugin</artifactId>
<version>3.0.2</version>
<configuration>
        <fork>false</fork>
        <log4jConfiguration>${basedir}/src/main/resources/log4j.properties</log4jConfiguration>
        <mappingIncludes>**/*.class</mappingIncludes>
        <verbose>true</verbose>
        <enhancerName>ASM</enhancerName>
        <api>JPA</api>
    <mappingExcludes>**/CustomRequestFactoryServlet.class, **/GaeAuthFilter.class</mappingExcludes>
</configuration>
<executions>
    <execution>
        <phase>compile</phase>
        <goals>
            <goal>enhance</goal>
        </goals>
    </execution>
</executions>
<dependencies>
    <dependency>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-core</artifactId>
        <version>3.0.10</version>
    </dependency>
    <dependency>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-enhancer</artifactId>
        <version>3.1.0-m2</version>
    </dependency>
    <dependency>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-api-jpa</artifactId>
        <version>3.0.9</version>
    </dependency>
</dependencies>
</plugin>

乾杯。

于 2012-09-09T09:47:52.627 に答える
1

「ランタイム」のスコープを datanucleus-core maven 依存関係に追加することで、これを修正しました。

于 2012-06-28T17:37:37.700 に答える