2014-01-15 55 views
1

我试图设置一个使用appengine插件的项目。我有多个错误,可能是因为我不知道如何将它们结合在一起。gradle with appengine插件

例如,当执行gradle appengineRun时,一切正常,直到我在浏览器中打开网站的那一刻。然后我收到:

org.datanucleus.exceptions.NucleusUserException: 
Found Meta-Data for class com.sample.Message but this class is not enhanced!! 
Please enhance the class before running DataNucleus. 

快看看任务列表表明,有适当的任务:appengineEnhance。不幸的是,当任务运行时,它会失败并带有神秘的异常J ava returned: 1。但在日志中我发现更多的描述性消息:

java.lang.RuntimeException: Unexpected exception 
    at com.google.appengine.tools.enhancer.Enhancer.execute(Enhancer.java:76) 
    at com.google.appengine.tools.enhancer.Enhance.<init>(Enhance.java:71) 
    at com.google.appengine.tools.enhancer.Enhance.main(Enhance.java:51) 
Caused by: java.lang.reflect.InvocationTargetException 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:601) 
    at com.google.appengine.tools.enhancer.Enhancer.execute(Enhancer.java:74) 
    ... 2 more 
Caused by: java.lang.NoSuchMethodError: org.datanucleus.plugin.PluginManager.<init>(Lorg/datanucleus/PersistenceConfiguration;Lorg/datanucleus/ClassLoaderResolver;)V 
    at org.datanucleus.OMFContext.<init>(OMFContext.java:159) 
    at org.datanucleus.enhancer.DataNucleusEnhancer.<init>(DataNucleusEnhancer.java:172) 
    at org.datanucleus.enhancer.DataNucleusEnhancer.<init>(DataNucleusEnhancer.java:150) 
    at org.datanucleus.enhancer.DataNucleusEnhancer.main(DataNucleusEnhancer.java:1157) 
    ... 7 more 

据我了解,罐之间存在一些不兼容性。任何想法如何解决这个问题?

build.gradle文件如下:

buildscript { 
    repositories { 
     mavenCentral() 
    } 
    dependencies { 
     classpath 'com.google.appengine:gradle-appengine-plugin:1.8.7' 
    } 
} 

apply plugin: 'idea' 
apply plugin: 'java' 
apply plugin: 'war' 
apply plugin: 'appengine' 

repositories { 
    mavenLocal() 
    mavenCentral() 
} 

dependencies { 

    providedCompile 'com.google.code.gson:gson:2.2.2' 
    providedCompile 'com.google.guava:guava:14.0.1' 

    providedCompile 'org.apache.commons:commons-lang3:3.1' 
    providedCompile 'commons-io:commons-io:2.4' 

    def jacksonVer = '2.2.0' 

    providedCompile "com.fasterxml.jackson.core:jackson-core:$jacksonVer" 
    providedCompile "com.fasterxml.jackson.core:jackson-databind:$jacksonVer" 

    providedCompile 'javax:javaee-api:6.0' 
    providedCompile 'com.google.appengine:appengine-api-1.0-sdk:1.8.7' 
    providedCompile 'org.reflections:reflections:0.9.9-RC1' 
    providedCompile 'org.datanucleus:datanucleus-core:3.1.3' 

} 

task wrapper(type: Wrapper) { 
    gradleVersion = '1.10' 
} 

appengine { 
    httpPort = 6380 
} 
+1

对我来说,就好像您使用的Datanucleus库与AppEngine SDK版本不兼容。我试图在AppEngine邮件列表上询问这个问题。 –

回答

0

一段时间后,事实证明,这是非常愚蠢的错误其实。最初开发项目的人(在最初)没有使用任何构建工具并直接从eclipse进行部署。在eclipse中他已经准备好war结构,并且所有分类都被复制到WEB-INF/classes其中... .gitignore文件被放置为忽略上述目录的内容。 appengine工作正常!