【发布时间】:2015-05-02 10:53:37
【问题描述】:
当我故意在 Objectify 事务中抛出异常时,我的事务不会被回滚。我做错了什么?
@Inject
Dao dao
...
public void testTransaction(){
dao.transact(new VoidWork() {
@Override
public void vrun() {
Key aclKey= dao.save().entity(acl).now(); //expecting this to be rolled back
//throw exception
if(true) throw new IllegalArgumentException();
//expecting rollback of acl save
}
});
}
我正在使用这样的设置:
@Singleton
public class DaoFactory extends ObjectifyFactory {
private Injector injector;
@Inject
public DaoFactory(Injector injector) {
this.injector = injector;
registerEntities();
}
private void registerEntities() {
}
@Override
public <T> T construct(Class<T> type) {
return injector.getInstance(type);
}
@Override
public Objectify begin() {
Dao dao = new Dao(this);
return dao;
}
}
地点:
public class Dao extends ObjectifyImpl<Dao> {
@Inject
public Dao(ObjectifyFactory fact) {
super(fact);
}
}
和
public class DaoService {
@Inject
public static void setObjectifyFactory(DaoFactory fact) {
ObjectifyService.setFactory(fact);
}
}
都是使用 Guice for DI 注入的。
我单步执行了代码,objectify 确实在 TransactorNo.class 中调用了 txnOfy.getTransaction().rollback();
但是,当我检查 app-engine 本地数据库时,我看到一个为 acl 创建的实体(有时需要几秒钟的时间才能显示出来)
【问题讨论】:
标签: objectify google-cloud-datastore