我使用Spark Framework开始了一个小项目,我选择了ActiveJDBC作为它的ORM,它使用Gradle来构建所有的东西。
(更新,使用ActiveJDBC 1.4.12)
这是我的build.gradle
文件:
buildscript {
repositories {
mavenCentral()
maven { url 'http://repo.javalite.io' }
}
dependencies {
classpath group: 'org.javalite', name: 'activejdbc-gradle-plugin', version: '1.4.13-SNAPSHOT'
}
}
apply plugin: 'java'
apply plugin: 'org.javalite.activejdbc'
repositories {
mavenCentral()
}
dependencies {
compile group: 'org.slf4j', name: 'slf4j-simple', version: '1.7.20'
compile group: 'com.sparkjava', name: 'spark-core', version: '2.5'
compile group: 'junit', name: 'junit', version: '4.12'
compile group: 'org.postgresql', name: 'postgresql', version: '9.4.1211.jre7'
compile group: 'org.javalite', name: 'activejdbc', version: '1.4.13-SNAPSHOT'
compile group: 'org.javalite', name: 'activejdbc-instrumentation', version: '1.4.13-SNAPSHOT'
}
task runApp(dependsOn: 'build', type: JavaExec) {
classpath = sourceSets.main.runtimeClasspath
main = "my.app.Application"
}
我是一个简单的模型,可以访问所有很酷的模型方法:
public class User extends Model {}
当我尝试构建项目时,问题就出现了:
Execution failed for task ':instrumentModels'.
> org.javalite.instrumentation.InstrumentationException: java.lang.RuntimeException: my.app.model.User class is frozen
* Exception is:
...
java.lang.RuntimeException: org.javalite.instrumentation.InstrumentationException: java.lang.RuntimeException:my.app.model.User class is frozen
at org.javalite.instrumentation.Instrumentation.instrument(Instrumentation.java:70)
at org.javalite.instrumentation.Instrumentation$instrument.call(Unknown Source)
at org.javalite.instrumentation.gradle.ActiveJDBCInstrumentation.instrument(ActiveJDBCInstrumentation.groovy:30)
at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:75)
at org.gradle.api.internal.project.taskfactory.DefaultTaskClassInfoStore$StandardTaskAction.doExecute(DefaultTaskClassInfoStore.java:136)
at org.gradle.api.internal.project.taskfactory.DefaultTaskClassInfoStore$StandardTaskAction.execute(DefaultTaskClassInfoStore.java:129)
at org.gradle.api.internal.project.taskfactory.DefaultTaskClassInfoStore$StandardTaskAction.execute(DefaultTaskClassInfoStore.java:118)
at org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:623)
at org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:606)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:80)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:61)
... 68 more
Caused by: org.javalite.instrumentation.InstrumentationException: java.lang.RuntimeException: my.app.model.User class is frozen
at org.javalite.instrumentation.ModelInstrumentation.instrument(ModelInstrumentation.java:43)
at org.javalite.instrumentation.Instrumentation.instrument(Instrumentation.java:57)
... 78 more
Caused by: java.lang.RuntimeException: my.app.model.User class is frozen
at javassist.CtClassType.checkModify(CtClassType.java:288)
at javassist.CtBehavior.setBody(CtBehavior.java:432)
at javassist.CtBehavior.setBody(CtBehavior.java:412)
at org.javalite.instrumentation.ModelInstrumentation.doInstrument(ModelInstrumentation.java:53)
at org.javalite.instrumentation.ModelInstrumentation.instrument(ModelInstrumentation.java:40)
... 79 more
答案 0 :(得分:1)
这是一个已知的错误,几天前在这里修复过:https://github.com/javalite/activejdbc/issues/537 请在这里获取最新的1.4.13-SNAPSHOT:http://repo.javalite.io。
更新:
基本上,这个异常是由于Instrumentation插件使用的Javassist拒绝对该类进行检测,因为它已经在当前VM中进行了检测。对于无关紧要的非Gradle项目,因为过程在检测后退出,但Gradle过程保持不变。问题已得到解决,应该有效。