在gcloud-node事务中捕获错误

时间:2016-04-15 17:56:32

标签: node.js google-app-engine google-cloud-datastore gcloud-node

我正在尝试捕获事务错误。我有以下代码应该导致错误,因为这些实体已经存在,但控制台中没有输出任何内容:

        datastore.runInTransaction(function(transaction, done) {


          transaction.save([
            {
              key: my_key1,
              method: 'insert',
              data: {
                stuff: 'stuff'
              }
            },
            {
              key:  my_key2,
              method: 'insert',
              data: {
                stuff: 'stuff'
              }
            }
          ]);


          console.log('here');
          done(function(err, data) {
            if (err) {
                console.log('err : ' + err);
                transaction.rollback();
               return;
            }
            console.log('no error');
            return;
          });


        });

});

1 个答案:

答案 0 :(得分:2)

done没有回复。将该回调作为runInTransaction的第二个参数。

var cachedTransaction;
datastore.runInTransaction(function(transaction, done) {
  cachedTransaction = transaction;

  transaction.save([
    {
      key: my_key1,
      method: 'insert',
      data: {
        stuff: 'stuff'
      }
    },
    {
      key:  my_key2,
      method: 'insert',
      data: {
        stuff: 'stuff'
      }
    }
  ]);

  done();
}, function(err) {
  if (err) {
    console.log('err : ' + err);
    cachedTransaction.rollback();
    return;
  }

  console.log('no error');
});

注意:我们正在为此制定更好的API:https://github.com/GoogleCloudPlatform/gcloud-node/issues/633