Browse Source

Merge pull request #282 from matiu/feat/handle-invalid

Feat/handle invalid
activeAddress
Ivan Socolsky 10 years ago
parent
commit
43be63859a
  1. 17
      lib/server.js
  2. 13
      test/integration/server.js

17
lib/server.js

@ -1420,13 +1420,18 @@ WalletService.prototype.getTxHistory = function(opts, cb) {
var now = Math.floor(Date.now() / 1000);
return _.map(txs, function(tx) {
var amountIn, amountOut, amountOutChange;
var amount, action, addressTo;
if (tx.outputs.length || tx.inputs.length) {
var inputs = classify(tx.inputs);
var outputs = classify(tx.outputs);
var amountIn = sum(inputs, true);
var amountOut = sum(outputs, true, false);
var amountOutChange = sum(outputs, true, true);
var amount, action, addressTo;
amountIn = sum(inputs, true);
amountOut = sum(outputs, true, false);
amountOutChange = sum(outputs, true, true);
if (amountIn == (amountOut + amountOutChange + (amountIn > 0 ? tx.fees : 0))) {
amount = amountOut;
action = 'moved';
@ -1442,6 +1447,10 @@ WalletService.prototype.getTxHistory = function(opts, cb) {
});
addressTo = firstExternalOutput ? firstExternalOutput.address : 'N/A';
};
} else {
action = 'invalid';
amount = 0;
}
var newTx = {
txid: tx.txid,

13
test/integration/server.js

@ -3592,6 +3592,19 @@ describe('Wallet service', function() {
done();
});
});
it('should handle invalid tx in history ', function(done) {
var h = _.clone(TestData.history);
h.push({txid:'xx'})
helpers.stubHistory(h);
server.getTxHistory({}, function(err, txs) {
should.not.exist(err);
should.exist(txs);
txs.length.should.equal(3);
txs[2].action.should.equal('invalid');
done();
});
});
});
describe('#scan', function() {

Loading…
Cancel
Save