2015-07-01 1 views
0

Я новичок в ebean и scala/akka, и я пытаюсь сохранить минимальный класс класса как ebean. Мои зависимости заключаются в следующем:Почему я получаю java.lang.VerifyError при увеличении объекта ebean scala

scalaVersion := "2.11.5" 

libraryDependencies ++= Seq(
    "com.typesafe.akka" %% "akka-actor" % "2.3.9", 
    "com.typesafe.akka" %% "akka-remote" % "2.3.9", 
    "com.typesafe.akka" %% "akka-cluster" % "2.3.9", 
    "com.typesafe.akka" %% "akka-testkit" % "2.3.9" % "test", 
    "org.scalatest" %% "scalatest" % "2.2.4" % "test", 
    "com.typesafe.slick" %% "slick" % "3.0.0", 
    "com.typesafe.slick" %% "slick-codegen" % "3.0.0", 
    "org.sorm-framework" % "sorm" % "0.3.18", 
    "org.avaje.ebeanorm" % "avaje-ebeanorm" % "4.7.1", 
    "org.avaje.ebeanorm" % "avaje-ebeanorm-agent" % "4.5.3", 
    "org.avaje" % "avaje-agentloader" % "1.1.3", 
    "org.apache.commons" % "commons-pool2" % "2.0") 

и мою сущность:

package zw.co.esol.eswitch.model 

import javax.persistence.Entity 
import javax.persistence.Id 
import com.avaje.ebean.Model 

@Entity 
case class Test(@Id id: Long, firstname: String) extends Model 

и моя главная:

object ApplicationMain extends App { 

    val system = ActorSystem("eswitch", ConfigFactory.load()) 

    //system.logConfiguration() 

    // Load the agent into the running JVM process 
    if (!AgentLoader.loadAgentFromClasspath("avaje-ebeanorm-agent","debug=1;packages=zw.co.esol.eswitch.model.*")) { 
     println("avaje-ebeanorm-agent not found in classpath - not dynamically loaded"); 
    } 

    EbeanDbServer.init 
    //more code follows....... 

и мой ebean код инициализации:

object EbeanDbServer { 

    def init = { 

    // programmatically build a EbeanServer instance 
    // specify the configuration... 

    println("@@ Starting EbeanServer...") 

    var config = new ServerConfig(); 
    config.setName("pgtest"); 

    // Define DataSource parameters 
    var postgresDb = new DataSourceConfig(); 
    postgresDb.setDriver("com.mysql.jdbc.Driver"); 
    postgresDb.setUsername("user"); 
    postgresDb.setPassword("password"); 
    postgresDb.setUrl("jdbc:mysql://127.0.0.1:3306/eswitch"); 
    postgresDb.setHeartbeatSql("select count(*) from message"); 

    config.setDataSourceConfig(postgresDb); 

    // specify a JNDI DataSource 
    // config.setDataSourceJndiName("someJndiDataSourceName"); 

    // set DDL options... 
    config.setDdlGenerate(false); 
    config.setDdlRun(false); 

    config.setDefaultServer(false); 
    config.setRegister(false); 

    var test = Test(1, "stan") 
    // automatically determine the DatabasePlatform 
    // using the jdbc driver 
    // config.setDatabasePlatform(new PostgresPlatform()); 

    // specify the entity classes (and listeners etc) 
    // ... if these are not specified Ebean will search 
    // ... the classpath looking for entity classes. 

     config.addClass(classOf[Test]); 

    // specify jars to search for entity beans 
// config.addJar("someJarThatContainsEntityBeans.jar"); 

    // create the EbeanServer instance 
    val server: EbeanServer = EbeanServerFactory.create(config); 

    println("@@ EbeanServer started... : " + server.getName) 

    } 
} 

Но я получить результат при запуске приложения:

ebean-enhance> cls: zw/co/esol/eswitch/model/Test msg: ... skipping add equals() ... already has equals() hashcode() methods 
ebean-enhance> cls: zw/co/esol/eswitch/model/Test msg: enhanced 
[error] (run-main-0) java.lang.VerifyError: Bad type on operand stack 
[error] Exception Details: 
[error] Location: 
[error]  zw/co/esol/eswitch/model/Test.<init>(JLjava/lang/String;)V @2: invokevirtual 
[error] Reason: 
[error]  Type uninitializedThis (current frame, stack[0]) is not assignable to 'zw/co/esol/eswitch/model/Test' 
[error] Current Frame: 
[error]  bci: @2 
[error]  flags: { flagThisUninit } 
[error]  locals: { uninitializedThis, long, long_2nd, 'java/lang/String' } 
[error]  stack: { uninitializedThis, long, long_2nd } 
[error] Bytecode: 
[error]  0000000: 2a1f b600 932a 2db6 0096 2ab7 0099 2abb 
[error]  0000010: 009b 592a b700 9eb5 00a0 2ab8 00a6 b1 
java.lang.VerifyError: Bad type on operand stack 
Exception Details: 
    Location: 
    zw/co/esol/eswitch/model/Test.<init>(JLjava/lang/String;)V @2: invokevirtual 
    Reason: 
    Type uninitializedThis (current frame, stack[0]) is not assignable to 'zw/co/esol/eswitch/model/Test' 
    Current Frame: 
    bci: @2 
    flags: { flagThisUninit } 
    locals: { uninitializedThis, long, long_2nd, 'java/lang/String' } 
    stack: { uninitializedThis, long, long_2nd } 
    Bytecode: 
    0000000: 2a1f b600 932a 2db6 0096 2ab7 0099 2abb 
    0000010: 009b 592a b700 9eb5 00a0 2ab8 00a6 b1 

     at zw.co.esol.eswitch.database.EbeanDbServer$.init(EbeanDbServer.scala:45) 
     at zw.co.esol.eswitch.global.ApplicationMain$.delayedEndpoint$zw$co$esol$eswitch$global$ApplicationMain$1(ApplicationMain.scala:28) 
     at zw.co.esol.eswitch.global.ApplicationMain$delayedInit$body.apply(ApplicationMain.scala:17) 
     at scala.Function0$class.apply$mcV$sp(Function0.scala:40) 
     at scala.runtime.AbstractFunction0.apply$mcV$sp(AbstractFunction0.scala:12) 
     at scala.App$$anonfun$main$1.apply(App.scala:76) 
     at scala.App$$anonfun$main$1.apply(App.scala:76) 
     at scala.collection.immutable.List.foreach(List.scala:381) 
     at scala.collection.generic.TraversableForwarder$class.foreach(TraversableForwarder.scala:35) 
     at scala.App$class.main(App.scala:76) 
     at zw.co.esol.eswitch.global.ApplicationMain$.main(ApplicationMain.scala:17) 
     at zw.co.esol.eswitch.global.ApplicationMain.main(ApplicationMain.scala) 
     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:606) 

Я использую версию Java 1.7.0_55 для Linux x86_64.

Что я могу делать неправильно? Я попытался найти решение, но все темы, которые я видел до сих пор, не помогают.

+0

Вы нашли решение? Если это так, поделитесь со мной? – tg44

ответ

1

Для некоторых людей, которые могли бы быть перед этой ошибки с помощью ebean без playframework

В вашей модели, если вы возвращаете класс POJO в любой функции, и если эта ошибка возникает при запуске данного блока тестовый случай или другой сценарий затем добавить setter и getter в классе POJO или любом неродственном классе модели и использовать эти функции для решения этой проблемы. не напрямую обращаться к переменным-членам и манипулировать ими. который вызывает эту ошибку. когда я создал весь геттер/сеттер, он разрешил проблему для меня