Browse Source

Merge pull request #213 from isocolsky/ref/error_message

Refactor blockchain errors
activeAddress
Matias Alejo Garcia 10 years ago
parent
commit
cb0e593014
  1. 23
      lib/server.js
  2. 2
      package.json
  3. 58
      test/integration/server.js

23
lib/server.js

@ -603,7 +603,10 @@ WalletService.prototype._getUtxos = function(cb) {
var bc = self._getBlockchainExplorer('insight', networkName); var bc = self._getBlockchainExplorer('insight', networkName);
bc.getUnspentUtxos(addressStrs, function(err, inutxos) { bc.getUnspentUtxos(addressStrs, function(err, inutxos) {
if (err) return cb(new Error('Could not fetch unspend outputs:' + err)); if (err) {
log.error('Could not fetch unspent outputs', err);
return cb(new ClientError('BLOCKCHAINERROR', 'Could not fetch unspent outputs'));
}
var utxos = _.map(inutxos, function(i) { var utxos = _.map(inutxos, function(i) {
return _.pick(i.toObject(), ['txid', 'vout', 'address', 'scriptPubKey', 'amount', 'satoshis']); return _.pick(i.toObject(), ['txid', 'vout', 'address', 'scriptPubKey', 'amount', 'satoshis']);
}); });
@ -911,7 +914,11 @@ WalletService.prototype._broadcastTx = function(txp, cb) {
} }
var bc = this._getBlockchainExplorer('insight', txp.getNetworkName()); var bc = this._getBlockchainExplorer('insight', txp.getNetworkName());
bc.broadcast(raw, function(err, txid) { bc.broadcast(raw, function(err, txid) {
return cb(err, txid); if (err) {
log.error('Could not broadcast transaction', err);
return cb(new ClientError('BLOCKCHAINERROR', 'Could not broadcast transaction'));
}
return cb(null, txid);
}) })
}; };
@ -1283,8 +1290,10 @@ WalletService.prototype.getTxHistory = function(opts, cb) {
}, },
function(next) { function(next) {
bc.getTransactions(addressStrs, null, null, function(err, txs) { bc.getTransactions(addressStrs, null, null, function(err, txs) {
if (err) return next(new Error('Could not fetch transactions: ' + err)); if (err) {
log.error('Could not fetch transactions', err);
return next(new ClientError('BLOCKCHAINERROR', 'Could not fetch transactions'));
}
next(null, self._normalizeTxHistory(txs)); next(null, self._normalizeTxHistory(txs));
}); });
}, },
@ -1342,7 +1351,11 @@ WalletService.prototype.scan = function(opts, cb) {
if (err) return next(err); if (err) return next(err);
networkName = networkName || Bitcore.Address(addresses[0].address).toObject().network; networkName = networkName || Bitcore.Address(addresses[0].address).toObject().network;
checkActivity(_.pluck(addresses, 'address'), networkName, function(err, thereIsActivity) { checkActivity(_.pluck(addresses, 'address'), networkName, function(err, thereIsActivity) {
if (err) return next(new Error('Could not fetch TX activity:' + err)); if (err) {
log.error('Could not check address activity', err);
return next(new ClientError('BLOCKCHAINERROR', 'Could not check address activity'));
}
activity = thereIsActivity; activity = thereIsActivity;
if (thereIsActivity) { if (thereIsActivity) {
allAddresses.push(addresses); allAddresses.push(addresses);

2
package.json

@ -2,7 +2,7 @@
"name": "bitcore-wallet-service", "name": "bitcore-wallet-service",
"description": "A service for Mutisig HD Bitcoin Wallets", "description": "A service for Mutisig HD Bitcoin Wallets",
"author": "BitPay Inc", "author": "BitPay Inc",
"version": "0.0.28", "version": "0.0.29",
"keywords": [ "keywords": [
"bitcoin", "bitcoin",
"copay", "copay",

58
test/integration/server.js

@ -902,6 +902,17 @@ describe('Wallet service', function() {
}); });
}); });
}); });
it('should fail gracefully when blockchain is unreachable', function(done) {
blockchainExplorer.getUnspentUtxos = sinon.stub().callsArgWith(1, 'dummy error');
server.createAddress({}, function(err, address) {
should.not.exist(err);
server.getBalance({}, function(err, balance) {
should.exist(err);
err.code.should.equal('BLOCKCHAINERROR');
done();
});
});
});
}); });
describe('Wallet not complete tests', function() { describe('Wallet not complete tests', function() {
@ -1032,6 +1043,19 @@ describe('Wallet service', function() {
}); });
}); });
it('should fail gracefully if unable to reach the blockchain', function(done) {
blockchainExplorer.getUnspentUtxos = sinon.stub().callsArgWith(1, 'dummy error');
server.createAddress({}, function(err, address) {
should.not.exist(err);
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 80, 'some message', TestData.copayers[0].privKey_1H_0);
server.createTx(txOpts, function(err, tx) {
should.exist(err);
err.code.should.equal('BLOCKCHAINERROR');
done();
});
});
});
it('should fail to create tx with invalid proposal signature', function(done) { it('should fail to create tx with invalid proposal signature', function(done) {
helpers.stubUtxos(server, wallet, [100, 200], function() { helpers.stubUtxos(server, wallet, [100, 200], function() {
@ -1676,6 +1700,7 @@ describe('Wallet service', function() {
txProposalId: txpid txProposalId: txpid
}, function(err) { }, function(err) {
should.exist(err); should.exist(err);
err.code.should.equal('BLOCKCHAINERROR');
server.getTx({ server.getTx({
txProposalId: txpid txProposalId: txpid
}, function(err, txp) { }, function(err, txp) {
@ -2691,6 +2716,14 @@ describe('Wallet service', function() {
}); });
}, done); }, done);
}); });
it('should fail gracefully if unable to reach the blockchain', function(done) {
blockchainExplorer.getTransactions = sinon.stub().callsArgWith(3, 'dummy error');
server.getTxHistory({}, function(err, txs) {
should.exist(err);
err.code.should.equal('BLOCKCHAINERROR');
done();
});
});
}); });
describe('#scan', function() { describe('#scan', function() {
@ -2727,6 +2760,9 @@ describe('Wallet service', function() {
]; ];
server.scan({}, function(err) { server.scan({}, function(err) {
should.not.exist(err); should.not.exist(err);
server.getWallet({}, function(err, wallet) {
should.not.exist(err);
wallet.scanStatus.should.equal('success');
server.storage.fetchAddresses(wallet.id, function(err, addresses) { server.storage.fetchAddresses(wallet.id, function(err, addresses) {
should.exist(addresses); should.exist(addresses);
addresses.length.should.equal(expectedPaths.length); addresses.length.should.equal(expectedPaths.length);
@ -2737,7 +2773,8 @@ describe('Wallet service', function() {
address.path.should.equal('m/2147483647/0/4'); address.path.should.equal('m/2147483647/0/4');
done(); done();
}); });
}) });
});
}); });
}); });
it('should scan main addresses & copayer addresses', function(done) { it('should scan main addresses & copayer addresses', function(done) {
@ -2814,8 +2851,22 @@ describe('Wallet service', function() {
done(); done();
}); });
}); });
it.skip('should abort scan if there is an error checking address activity', function(done) {}); it('should abort scan if there is an error checking address activity', function(done) {
blockchainExplorer.getAddressActivity = sinon.stub().callsArgWith(1, 'dummy error');
server.scan({}, function(err) {
should.exist(err);
err.code.should.equal('BLOCKCHAINERROR');
server.getWallet({}, function(err, wallet) {
should.not.exist(err);
wallet.scanStatus.should.equal('error');
server.storage.fetchAddresses(wallet.id, function(err, addresses) {
should.not.exist(err);
addresses.should.be.empty;
done();
});
});
});
});
}); });
describe('#startScan', function() { describe('#startScan', function() {
@ -3134,6 +3185,7 @@ describe('Wallet service', function() {
}); });
}); });
}); });
describe('Email notifications', function() { describe('Email notifications', function() {
var server, wallet, sendMailStub; var server, wallet, sendMailStub;
beforeEach(function(done) { beforeEach(function(done) {

Loading…
Cancel
Save