数据核增强失败
Posted
技术标签:
【中文标题】数据核增强失败【英文标题】:Failed to enhance data nucleus 【发布时间】:2015-02-18 00:07:42 【问题描述】:将我的 gradle 更新到 1.0.1 后,我的 appengine 构建失败
我得到错误:
groovy.lang.MissingPropertyException: Could not find property 'enhancerApi' on com.google.appengine.AppEnginePluginExtension_Decorated@1dd443c1
看起来enhacerApi
已被弃用,但我不知道如何解决这个问题。
App Engine SDK 根 = C:\Users\steve.gradle\appengine-sdk\appengine-java-sdk-1.9.17 Java 类路径 = C:\workspace\ShoutBox\gradle\wrapper\gradle-wrapper.jar;C:\Users\steve.gradle\appengine-sdk\appengine-java-sdk-1.9.17\lib\appengine-tools-api 。罐 Webapp 源目录 = C:\workspace\ShoutBox\appengine\src\main\webapp 增强 DataNucleus 类... 已完成对 DataNucleus 类的增强。 :appengine:appengineEnhance 失败 :appengine:appengineEnhance (Thread[main,5,main]) 完成。耗时 1.043 秒。
FAILURE:构建失败并出现异常。
出了什么问题: 任务 ':appengine:appengineEnhance' 执行失败。
增强 DataNucleus 类时发生错误。
试试: 使用 --debug 选项运行以获得更多日志输出。
例外情况是: org.gradle.api.tasks.TaskExecutionException:任务“:appengine:appengineEnhance”的执行失败。 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:69) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:46) 在 org.gradle.api.internal.tasks.execution.PostExecutionAnalysisTaskExecuter.execute(PostExecutionAnalysisTaskExecuter.java:35) 在 org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:64) 在 org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:58) 在 org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:42) 在 org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:52) 在 org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:53) 在 org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43) 在 org.gradle.api.internal.AbstractTask.executeWithoutThrowingTaskFailure(AbstractTask.java:305) 在 org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.executeTask(AbstractTaskPlanExecutor.java:79) 在 org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.processTask(AbstractTaskPlanExecutor.java:63) 在 org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.run(AbstractTaskPlanExecutor.java:51) 在 org.gradle.execution.taskgraph.DefaultTaskPlanExecutor.process(DefaultTaskPlanExecutor.java:23) 在 org.gradle.execution.taskgraph.DefaultTaskGraphExecuter.execute(DefaultTaskGraphExecuter.java:88) 在 org.gradle.execution.SelectedTaskExecutionAction.execute(SelectedTaskExecutionAction.java:29) 在 org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:62) 在 org.gradle.execution.DefaultBuildExecuter.access $200(DefaultBuildExecuter.java:23) 在 org.gradle.execution.DefaultBuildExecuter$2.proceed(DefaultBuildExecuter.java:68) 在 org.gradle.execution.DryRunBuildExecutionAction.execute(DryRunBuildExecutionAction.java:32) 在 org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:62) 在 org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:55) 在 org.gradle.initialization.DefaultGradleLauncher.doBuildStages(DefaultGradleLauncher.java:149) 在 org.gradle.initialization.DefaultGradleLauncher.doBuild(DefaultGradleLauncher.java:106) 在 org.gradle.initialization.DefaultGradleLauncher.run(DefaultGradleLauncher.java:86) 在 org.gradle.launcher.exec.InProcessBuildActionExecuter$DefaultBuildController.run(InProcessBuildActionExecuter.java:80) 在 org.gradle.launcher.cli.ExecuteBuildAction.run(ExecuteBuildAction.java:33) 在 org.gradle.launcher.cli.ExecuteBuildAction.run(ExecuteBuildAction.java:24) 在 org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:36) 在 org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:26) 在 org.gradle.launcher.cli.RunBuildAction.run(RunBuildAction.java:51) 在 org.gradle.internal.Actions$RunnableActionAdapter.execute(Actions.java:171) 在 org.gradle.launcher.cli.CommandLineActionFactory$ParseAndBuildAction.execute(CommandLineActionFactory.java:237) 在 org.gradle.launcher.cli.CommandLineActionFactory$ParseAndBuildAction.execute(CommandLineActionFactory.java:210) 在 org.gradle.launcher.cli.JavaRuntimeValidationAction.execute(JavaRuntimeValidationAction.java:35) 在 org.gradle.launcher.cli.JavaRuntimeValidationAction.execute(JavaRuntimeValidationAction.java:24) 在 org.gradle.launcher.cli.CommandLineActionFactory$WithLogging.execute(CommandLineActionFactory.java:206) 在 org.gradle.launcher.cli.CommandLineActionFactory$WithLogging.execute(CommandLineActionFactory.java:169) 在 org.gradle.launcher.cli.ExceptionReportingAction.execute(ExceptionReportingAction.java:33) 在 org.gradle.launcher.cli.ExceptionReportingAction.execute(ExceptionReportingAction.java:22) 在 org.gradle.launcher.Main.doAction(Main.java:33) 在 org.gradle.launcher.bootstrap.EntryPoint.run(EntryPoint.java:45) 在 org.gradle.launcher.bootstrap.ProcessBootstrap.runNoExit(ProcessBootstrap.java:54) 在 org.gradle.launcher.bootstrap.ProcessBootstrap.run(ProcessBootstrap.java:35) 在 org.gradle.launcher.GradleMain.main(GradleMain.java:23) 在 org.gradle.wrapper.BootstrapMainStarter.start(BootstrapMainStarter.java:33) 在 org.gradle.wrapper.WrapperExecutor.execute(WrapperExecutor.java:130) 在 org.gradle.wrapper.GradleWrapperMain.main(GradleWrapperMain.java:48) 原因:org.gradle.api.GradleException:增强 DataNucleus 类时发生错误。 在 com.google.appengine.task.EnhanceTask.enhanceClasses(EnhanceTask.groovy:58) 在 com.google.appengine.task.EnhanceTask.executeTask(EnhanceTask.groovy:34) 在 com.google.appengine.task.AbstractTask.start(AbstractTask.groovy:38) 在 org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:63) 在 org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.doExecute(AnnotationProcessingTaskFactory.java:218) 在 org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.execute(AnnotationProcessingTaskFactory.java:211) 在 org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.execute(AnnotationProcessingTaskFactory.java:200) 在 org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:579) 在 org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:562) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:80) 在 org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:61) ... 47 更多 原因:groovy.lang.MissingPropertyException:在 com.google.appengine.AppEnginePluginExtension_Decorated@1dd443c1 上找不到属性“enhancerApi”。 在 org.gradle.api.internal.AbstractDynamicObject.propertyMissingException(AbstractDynamicObject.java:43) 在 org.gradle.api.internal.AbstractDynamicObject.getProperty(AbstractDynamicObject.java:35) 在 org.gradle.api.internal.CompositeDynamicObject.getProperty(CompositeDynamicObject.java:94) 在 com.google.appengine.AppEnginePluginExtension_Decorated.getProperty(未知来源) 在 com.google.appengine.AppEnginePlugin$_configureEnhance_closure9_closure58.doCall(AppEnginePlugin.groovy:313) 在 com.google.appengine.AppEnginePlugin$_configureEnhance_closure9_closure58.doCall(AppEnginePlugin.groovy) 在 org.gradle.api.internal.ConventionAwareHelper$2.getValue(ConventionAwareHelper.java:84) 在 org.gradle.api.internal.ConventionAwareHelper$MappedPropertyImpl.getValue(ConventionAwareHelper.java:136) 在 org.gradle.api.internal.ConventionAwareHelper.getConventionValue(ConventionAwareHelper.java:114) 在 com.google.appengine.task.EnhanceTask_Decorated.getEnhancerApi(未知来源) 在 com.google.appengine.task.EnhanceTask$_enhanceClasses_closure1.doCall(EnhanceTask.groovy:52) 在 com.google.appengine.task.EnhanceTask$_enhanceClasses_closure1.doCall(EnhanceTask.groovy) 在 org.gradle.api.internal.project.ant.BasicAntBuilder.doInvokeMethod(BasicAntBuilder.java:92) 在 com.google.appengine.task.EnhanceTask.enhanceClasses(EnhanceTask.groovy:42) ... 57 更多
编译失败
总时间:19.158 秒 已停止 0 个编译器守护进程。
【问题讨论】:
【参考方案1】:在 gradle 构建文件中添加缺少的 api 标签解决了这个问题
enhancer
version = "v2"
api="jdo" // or "jpa"
enhanceOnBuild = true
【讨论】:
以上是关于数据核增强失败的主要内容,如果未能解决你的问题,请参考以下文章