java.lang.AbstractMethodError при попытке использовать Сиену с Play Framework - PullRequest
0 голосов
/ 27 августа 2011

Хорошо, я уже несколько дней бьюсь головой об этой проблеме, и я просто не знаю, чего мне не хватает, чтобы заставить ее работать. Я также пробовал многочисленные поиски здесь и в Google, но ничего не нашел, что приблизило меня к решению.

При попытке сохранить мою первую запись с помощью модуля crudsiena появляется экран «Исключение при выполнении» с сообщением:

AbstractMethodError occured: play.modules.gae.PlayDevEnvironment.enforceApiDeadlines()Z

Он говорит, что это происходит, In {module:crudsiena-2.0.2}/app/controllers/CRUD.java (around line 259)

Эта строка: SienaPlugin.pm().save(object);

Та же ошибка возникает, когда я создаю новый объект своей модели данных и пытаюсь save() проверить его в тесте JUnit.

Изначально я начал с implementation = siena.gae.GaePersistenceManager в siena.properties в той же папке, что и мой класс модели, но также попытался implementation = siena.jdbc.H2PersistanceManager, чтобы попробовать H2 DB в оперативной памяти, но все равно выдает ту же ошибку.

play modules сообщает о следующих модулях:

  • crudsiena-2.0.2
  • сиена-2.0.4

Из некоторого вывода журнала отладки, который я вставил в модульный тест, похоже, что даже с implementation = siena.jdbc.H2PersistanceManager, getPersistanceManager() при создании экземпляра моей модели возвращается объект siena.gae.GaePersistenceManager.

Мой класс модели данных выглядит следующим образом (примечание, имена переменных и столбцов здесь запутаны):

@Table("my_model")
public class MyModel extends Model {

    @Id(Generator.AUTO_INCREMENT)
    public Long id;

    @Column("index_alpha_numeric")
    @NotNull
    public String indexAlphaNumeric;

    @Column("extra_index_numbers")
    @Embedded
    public List<String> extraNumbers;

    @Column("string_value")
    @NotNull
    public String stringValue;

    @Column("another_string")
    @NotNull
    public String anotherString;

    @Column("another_index")
    @NotNull
    public Integer another_index;

    //empty no-param constructor, required if explicit constructor with parameters specified
    public MyModel() { }

    public MyModel(String aNum, String stringVal, String string2, Integer intIndex) {
        indexAlphaNumeric = aNum;
        stringValue = stringVal;
        anotherString = string2;
        anotherIndex = intIndex;
    }


    public static Query<MyModel> all() {
        return Model.all(MyModel.class);
    }

}

Я также пытался удалить встроенный список, просто чтобы посмотреть, не понял ли я, как это работает, но опять же, разницы не было.

Я не могу думать ни о чем другом, что мне, возможно, придется включить в этот вопрос прямо сейчас, но если вам понадобится дополнительная информация, о которой я не подумал, я, конечно, буду рад вам обязать.

Редактировать : меня спросили о трассировке стека, так что вот она. Эта трассировка стека взята из теста JUnit. Кажется, проблема в классах GAE, так что я собираюсь немного поболтать с этим.

java.lang.AbstractMethodError: play.modules.gae.PlayDevEnvironment.enforceApiDeadlines()Z
    at com.google.appengine.tools.development.ApiProxyLocalImpl.doAsyncCall(ApiProxyLocalImpl.java:190)
    at com.google.appengine.tools.development.ApiProxyLocalImpl.makeAsyncCall(ApiProxyLocalImpl.java:151)
    at com.google.apphosting.api.ApiProxy.makeAsyncCall(ApiProxy.java:182)
    at com.google.appengine.api.datastore.DatastoreApiHelper.makeAsyncCall(DatastoreApiHelper.java:81)
    at com.google.appengine.api.datastore.AsyncDatastoreServiceImpl.put(AsyncDatastoreServiceImpl.java:266)
    at com.google.appengine.api.datastore.DatastoreServiceImpl$2.runInternal(DatastoreServiceImpl.java:113)
    at com.google.appengine.api.datastore.DatastoreServiceImpl$2.runInternal(DatastoreServiceImpl.java:110)
    at com.google.appengine.api.datastore.TransactionRunner.runInTransaction(TransactionRunner.java:31)
    at com.google.appengine.api.datastore.DatastoreServiceImpl.put(DatastoreServiceImpl.java:110)
    at com.google.appengine.api.datastore.DatastoreServiceImpl.put(DatastoreServiceImpl.java:94)
    at siena.gae.GaePersistenceManager._insertSingle(GaePersistenceManager.java:285)
    at siena.gae.GaePersistenceManager._insertSingle(GaePersistenceManager.java:267)
    at siena.gae.GaePersistenceManager.insert(GaePersistenceManager.java:253)
    at siena.gae.GaePersistenceManager.save(GaePersistenceManager.java:894)
    at siena.Model.save(Model.java:87)
    at MyModelTest.addItem(MyModelTest.java:14)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at play.test.PlayJUnitRunner$StartPlay$2$1.evaluate(PlayJUnitRunner.java:98)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:76)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
    at play.test.PlayJUnitRunner.run(PlayJUnitRunner.java:48)
    at org.junit.runners.Suite.runChild(Suite.java:128)
    at org.junit.runners.Suite.runChild(Suite.java:24)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
    at org.junit.runner.JUnitCore.run(JUnitCore.java:157)
    at org.junit.runner.JUnitCore.run(JUnitCore.java:136)
    at org.junit.runner.JUnitCore.run(JUnitCore.java:117)
    at play.test.TestEngine.run(TestEngine.java:101)
    at controllers.TestRunner.run(TestRunner.java:67)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at play.mvc.ActionInvoker.invokeWithContinuation(ActionInvoker.java:546)
    at play.mvc.ActionInvoker.invoke(ActionInvoker.java:500)
    at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:476)
    at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:471)
    at play.mvc.ActionInvoker.invoke(ActionInvoker.java:159)
    at play.server.PlayHandler$NettyInvocation.execute(PlayHandler.java:220)
    at play.Invoker$Invocation.run(Invoker.java:265)
    at play.server.PlayHandler$NettyInvocation.run(PlayHandler.java:200)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
    at java.util.concurrent.FutureTask.run(FutureTask.java:138)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$301(ScheduledThreadPoolExecutor.java:98)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:206)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)

1 Ответ

1 голос
/ 27 августа 2011

Ваша проблема не в модели, по-видимому!Это в конфигурации Play + Siena IMO.Разве у вас нет полной трассировки стека?

Когда вы говорите, что используете "creation = siena.gae.GaePersistenceManager", это означает в файле siena.properties?Если да, удалите этот файл, вам не нужен файл siena.properties при использовании Play, так как Siena подключена к файлу Play application.conf.1005 *

...